Mobius не подгружает конфиги в idea

Psycho

Просветленный
Модератор
Орден Золотого Заката
Победитель в номинации 2023
Победитель в номинации 2022
Победитель в номинации 2021
Участник Новогоднего Фонда 2021
Неукротимое пламя
Старожил II степени
Победитель в номинации 2020
Победитель в номинации 2019
Знаток великого письма
Знаток письма
Веселый флудер
Мастер реакций
Любитель реакций
Знаток Lineage2
Старожил I степени
Победитель в номинации 2017
Победитель в номинации 2016
Медаль за активность на Форуме
За веру и верность форуму
Сообщения
4 447
Розыгрыши
1
Решения
3
Репутация
4 331
Реакции
2 796
Баллы
2 438
Хроники
  1. Chaotic Throne: High Five
Исходники
Присутствуют
Сборка
L2JMobius
Народ, подскажите, почему он не подгружает конфиги в идеи?
Все файлы присутствуют.
Логин:
Код:
мая 21, 2019 1:54:19 ПП l2j.loginserver.LoginServer <init>
WARNING: LoginServer: .\log.cfg (Не удается найти указанный файл)
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser <init>
WARNING: [LoginServer.ini] There was an error loading config reason: \config\LoginServer.ini (Системе не удается найти указанный путь)
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getString
WARNING: [LoginServer.ini] missing property for key: LoginHostname using default value: 127.0.0.1
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [LoginServer.ini] missing property for key: LoginPort using default value: 9013
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getString
WARNING: [LoginServer.ini] missing property for key: LoginserverHostname using default value: 0.0.0.0
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [LoginServer.ini] missing property for key: LoginserverPort using default value: 2106
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getString
WARNING: [LoginServer.ini] missing property for key: DatapackRoot using default value: .
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [LoginServer.ini] missing property for key: AcceptNewGameServer using default value: true
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [LoginServer.ini] missing property for key: LoginTryBeforeBan using default value: 5
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [LoginServer.ini] missing property for key: LoginBlockAfterBan using default value: 900
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [LoginServer.ini] missing property for key: LoginRestartSchedule using default value: false
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [LoginServer.ini] missing property for key: LoginRestartTime using default value: 24
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getString
WARNING: [LoginServer.ini] missing property for key: Driver using default value: org.mariadb.jdbc.Driver
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getString
WARNING: [LoginServer.ini] missing property for key: URL using default value: jdbc:mariadb://localhost/login?useUnicode=true&characterEncoding=utf-8
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getString
WARNING: [LoginServer.ini] missing property for key: Login using default value: user
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getString
WARNING: [LoginServer.ini] missing property for key: Password using default value: user
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [LoginServer.ini] missing property for key: MaximumDbConnections using default value: 10
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [LoginServer.ini] missing property for key: MaximumDbIdleTime using default value: 0
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [LoginServer.ini] missing property for key: BackupDatabase using default value: false
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getString
WARNING: [LoginServer.ini] missing property for key: MySqlBinLocation using default value:
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getString
WARNING: [LoginServer.ini] missing property for key: BackupPath using default value: ../backup/
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [LoginServer.ini] missing property for key: BackupDays using default value: 30
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [LoginServer.ini] missing property for key: ShowLicence using default value: true
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [LoginServer.ini] missing property for key: AutoCreateAccounts using default value: true
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [LoginServer.ini] missing property for key: EnableFloodProtection using default value: true
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [LoginServer.ini] missing property for key: FastConnectionLimit using default value: 15
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [LoginServer.ini] missing property for key: NormalConnectionTime using default value: 700
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [LoginServer.ini] missing property for key: FastConnectionTime using default value: 350
мая 21, 2019 1:54:19 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [LoginServer.ini] missing property for key: MaxConnectionPerIP using default value: 50
[main] INFO com.zaxxer.hikari.HikariDataSource - HikariPool-1 - Starting...
[main] INFO com.zaxxer.hikari.HikariDataSource - HikariPool-1 - Start completed.
мая 21, 2019 1:54:19 ПП l2j.commons.database.DatabaseFactory init
INFO: Database: Initialized.
мая 21, 2019 1:54:19 ПП l2j.loginserver.LoginController <init>
INFO: Loading LoginController...
мая 21, 2019 1:54:21 ПП l2j.loginserver.LoginController <init>
INFO: Cached 10 KeyPairs for RSA communication.
мая 21, 2019 1:54:21 ПП l2j.commons.util.IXmlReader parseFile
WARNING: Could not parse servername.xml is not a file or it doesn't exist!
мая 21, 2019 1:54:21 ПП l2j.loginserver.GameServerTable load
INFO: Loaded 0 server names.
мая 21, 2019 1:54:21 ПП l2j.loginserver.GameServerTable <init>
INFO: Loaded 1 registered Game Servers.
мая 21, 2019 1:54:21 ПП l2j.loginserver.GameServerTable <init>
INFO: Cached 10 RSA keys for Game Server communication.
мая 21, 2019 1:54:21 ПП l2j.loginserver.LoginServer loadBanFile
WARNING: IP Bans file (banned_ip.cfg) is missing or is a directory, skipped.
мая 21, 2019 1:54:21 ПП l2j.loginserver.LoginServer <init>
INFO: Listening for GameServers on 127.0.0.1:9013
мая 21, 2019 1:54:21 ПП l2j.commons.network.NetworkManager start
INFO: ClientNetworkManager: Listening on 0.0.0.0:2106
Гейм:
Код:
Exception in thread "main" java.io.FileNotFoundException: .\log.cfg (Не удается найти указанный файл)
    at java.base/java.io.FileInputStream.open0(Native Method)
    at java.base/java.io.FileInputStream.open(FileInputStream.java:220)
    at java.base/java.io.FileInputStream.<init>(FileInputStream.java:158)
    at l2j.gameserver.GameServer.<init>(GameServer.java:162)
    at l2j.gameserver.GameServer.main(GameServer.java:466)

Process finished with exit code 1
Java:
package l2j;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.math.BigInteger;
import java.net.Inet6Address;
import java.net.InetAddress;
import java.net.InterfaceAddress;
import java.net.NetworkInterface;
import java.net.SocketException;
import java.net.URL;
import java.net.UnknownHostException;
import java.nio.charset.StandardCharsets;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Enumeration;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Properties;
import java.util.Set;
import java.util.StringTokenizer;
import java.util.logging.Level;
import java.util.logging.Logger;
import java.util.regex.Pattern;
import java.util.regex.PatternSyntaxException;
import java.util.stream.Collectors;
import java.util.stream.IntStream;

import org.w3c.dom.Document;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;

import l2j.commons.util.IGameXmlReader;
import l2j.commons.util.PropertiesParser;
import l2j.gameserver.enums.ChatType;
import l2j.gameserver.enums.IllegalActionPunishmentType;
import l2j.gameserver.model.Location;
import l2j.gameserver.model.holders.ItemHolder;
import l2j.gameserver.util.FloodProtectorConfig;
import l2j.gameserver.util.Util;

public final class Config
{
    private static final Logger LOGGER = Logger.getLogger(Config.class.getName());
   
    // --------------------------------------------------
    // Constants
    // --------------------------------------------------
    public static final String EOL = System.lineSeparator();
   
    // --------------------------------------------------
    // Config File Definitions
    // --------------------------------------------------
    public static final String GEOENGINE_CONFIG_FILE = "/config/GeoEngine.ini";
    public static final String OLYMPIAD_CONFIG_FILE = "/config/Olympiad.ini";
    public static final String SIEGE_CONFIG_FILE = "/config/Siege.ini";
    public static final String FORTSIEGE_CONFIG_FILE = "/config/FortSiege.ini";
    public static final String TW_CONFIG_FILE = "/config/TerritoryWar.ini";
    private static final String CHARACTER_CONFIG_FILE = "/config/Character.ini";
    private static final String CH_SIEGE_CONFIG_FILE = "/config/ConquerableHallSiege.ini";
    private static final String FEATURE_CONFIG_FILE = "/config/Feature.ini";
    private static final String FLOOD_PROTECTOR_CONFIG_FILE = "/config/FloodProtector.ini";
    private static final String GENERAL_CONFIG_FILE = "/config/General.ini";
    private static final String GRACIASEEDS_CONFIG_FILE = "/config/GraciaSeeds.ini";
    private static final String GRANDBOSS_CONFIG_FILE = "/config/GrandBoss.ini";
    private static final String IDFACTORY_CONFIG_FILE = "/config/IdFactory.ini";
    private static final String LOGIN_CONFIG_FILE = "/config/LoginServer.ini";
    private static final String NPC_CONFIG_FILE = "/config/NPC.ini";
    private static final String PVP_CONFIG_FILE = "/config/PVP.ini";
    private static final String RATES_CONFIG_FILE = "/config/Rates.ini";
    private static final String GAME_CONFIG_FILE = "/config/GameServer.ini";
    private static final String TELNET_CONFIG_FILE = "/config/Telnet.ini";
    private static final String CHAT_FILTER_FILE = "/config/chatfilter.txt";
    private static final String HEXID_FILE = "/config/hexid.txt";
    private static final String IPCONFIG_FILE = "/config/ipconfig.xml";
   
    // --------------------------------------------------
    // Custom Config File Definitions
    // --------------------------------------------------
    public static final String CUSTOM_ALLOWED_PLAYER_RACES_CONFIG_FILE = "/config/Custom/AllowedPlayerRaces.ini";
    public static final String CUSTOM_AUTO_POTIONS_CONFIG_FILE = "/config/Custom/AutoPotions.ini";
    public static final String CUSTOM_BANKING_CONFIG_FILE = "/config/Custom/Banking.ini";
    public static final String CUSTOM_CHAMPION_MONSTERS_CONFIG_FILE = "/config/Custom/ChampionMonsters.ini";
    public static final String CUSTOM_CHAT_MODERATION_CONFIG_FILE = "/config/Custom/ChatModeration.ini";
    public static final String CUSTOM_COMMUNITY_BOARD_CONFIG_FILE = "/config/Custom/CommunityBoard.ini";
    public static final String CUSTOM_DUALBOX_CHECK_CONFIG_FILE = "/config/Custom/DualboxCheck.ini";
    public static final String CUSTOM_FACTION_SYSTEM_CONFIG_FILE = "/config/Custom/FactionSystem.ini";
    public static final String CUSTOM_FAKE_PLAYERS_CONFIG_FILE = "/config/Custom/FakePlayers.ini";
    public static final String CUSTOM_FIND_PVP_CONFIG_FILE = "/config/Custom/FindPvP.ini";
    public static final String CUSTOM_HELLBOUND_STATUS_CONFIG_FILE = "/config/Custom/HellboundStatus.ini";
    public static final String CUSTOM_MULTILANGUAL_SUPPORT_CONFIG_FILE = "/config/Custom/MultilingualSupport.ini";
    public static final String CUSTOM_NPC_STAT_MULTIPIERS_CONFIG_FILE = "/config/Custom/NpcStatMultipliers.ini";
    public static final String CUSTOM_OFFLINE_TRADE_CONFIG_FILE = "/config/Custom/OfflineTrade.ini";
    public static final String CUSTOM_PASSWORD_CHANGE_CONFIG_FILE = "/config/Custom/PasswordChange.ini";
    public static final String CUSTOM_PREMIUM_SYSTEM_CONFIG_FILE = "/config/Custom/PremiumSystem.ini";
    public static final String CUSTOM_PRIVATE_STORE_RANGE_CONFIG_FILE = "/config/Custom/PrivateStoreRange.ini";
    public static final String CUSTOM_PVP_ANNOUNCE_CONFIG_FILE = "/config/Custom/PvpAnnounce.ini";
    public static final String CUSTOM_PVP_REWARD_ITEM_CONFIG_FILE = "/config/Custom/PvpRewardItem.ini";
    public static final String CUSTOM_PVP_TITLE_CONFIG_FILE = "/config/Custom/PvpTitleColor.ini";
    public static final String CUSTOM_RANDOM_SPAWNS_CONFIG_FILE = "/config/Custom/RandomSpawns.ini";
    public static final String CUSTOM_SCREEN_WELCOME_MESSAGE_CONFIG_FILE = "/config/Custom/ScreenWelcomeMessage.ini";
    public static final String CUSTOM_SELL_BUFFS_CONFIG_FILE = "/config/Custom/SellBuffs.ini";
    public static final String CUSTOM_SERVER_TIME_CONFIG_FILE = "/config/Custom/ServerTime.ini";
    public static final String CUSTOM_SCHEME_BUFFER_CONFIG_FILE = "/config/Custom/ShemeBuffer.ini";
    public static final String CUSTOM_STARTING_LOCATION_CONFIG_FILE = "/config/Custom/StartingLocation.ini";
    public static final String CUSTOM_TVT_CONFIG_FILE = "/config/Custom/TeamVersusTeam.ini";
    public static final String CUSTOM_VOTE_REWARD_CONFIG_FILE = "/config/Custom/VoteReward.ini";
    public static final String CUSTOM_WAREHOUSE_SORTING_CONFIG_FILE = "/config/Custom/WarehouseSorting.ini";
    public static final String CUSTOM_WEDDING_CONFIG_FILE = "/config/Custom/Wedding.ini";
    public static final String CUSTOM_WALKER_BOT_PROTECTION_CONFIG_FILE = "/config/Custom/WalkerBotProtection.ini";
   
    // --------------------------------------------------
    // Variable Definitions
    // --------------------------------------------------
    public static boolean PLAYER_DELEVEL;
    public static boolean DECREASE_SKILL_LEVEL;
    public static double ALT_WEIGHT_LIMIT;
    public static int RUN_SPD_BOOST;
    public static int DEATH_PENALTY_CHANCE;
    public static double RESPAWN_RESTORE_CP;
    public static double RESPAWN_RESTORE_HP;
    public static double RESPAWN_RESTORE_MP;
    public static boolean ENABLE_MODIFY_SKILL_DURATION;
    public static Map<Integer, Integer> SKILL_DURATION_LIST;
    public static boolean ENABLE_MODIFY_SKILL_REUSE;
    public static Map<Integer, Integer> SKILL_REUSE_LIST;
    public static boolean AUTO_LEARN_SKILLS;
    public static boolean AUTO_LEARN_FS_SKILLS;
    public static boolean AUTO_LOOT_HERBS;
    public static byte BUFFS_MAX_AMOUNT;
    public static byte TRIGGERED_BUFFS_MAX_AMOUNT;
    public static byte DANCES_MAX_AMOUNT;
    public static boolean DANCE_CANCEL_BUFF;
    public static boolean DANCE_CONSUME_ADDITIONAL_MP;
    public static boolean ALT_STORE_DANCES;
    public static boolean AUTO_LEARN_DIVINE_INSPIRATION;
    public static boolean ALT_GAME_CANCEL_BOW;
    public static boolean ALT_GAME_CANCEL_CAST;
    public static boolean ALT_GAME_MAGICFAILURES;
    public static int PLAYER_FAKEDEATH_UP_PROTECTION;
    public static boolean STORE_SKILL_COOLTIME;
    public static boolean SUBCLASS_STORE_SKILL_COOLTIME;
    public static boolean SUMMON_STORE_SKILL_COOLTIME;
    public static boolean ALT_GAME_SHIELD_BLOCKS;
    public static int ALT_PERFECT_SHLD_BLOCK;
    public static long EFFECT_TICK_RATIO;
    public static boolean ALLOW_CLASS_MASTERS;
    public static ClassMasterSettings CLASS_MASTER_SETTINGS;
    public static boolean ALLOW_ENTIRE_TREE;
    public static boolean ALTERNATE_CLASS_MASTER;
    public static boolean LIFE_CRYSTAL_NEEDED;
    public static boolean ES_SP_BOOK_NEEDED;
    public static boolean DIVINE_SP_BOOK_NEEDED;
    public static boolean ALT_GAME_SKILL_LEARN;
    public static boolean ALT_GAME_SUBCLASS_WITHOUT_QUESTS;
    public static boolean ALT_GAME_SUBCLASS_EVERYWHERE;
    public static boolean ALLOW_TRANSFORM_WITHOUT_QUEST;
    public static int FEE_DELETE_TRANSFER_SKILLS;
    public static int FEE_DELETE_SUBCLASS_SKILLS;
    public static boolean RESTORE_SERVITOR_ON_RECONNECT;
    public static boolean RESTORE_PET_ON_RECONNECT;
    public static double MAX_BONUS_EXP;
    public static double MAX_BONUS_SP;
    public static int MAX_RUN_SPEED;
    public static int MAX_PATK;
    public static int MAX_MATK;
    public static int MAX_PCRIT_RATE;
    public static int MAX_MCRIT_RATE;
    public static int MAX_PATK_SPEED;
    public static int MAX_MATK_SPEED;
    public static int MAX_EVASION;
    public static int MIN_ABNORMAL_STATE_SUCCESS_RATE;
    public static int MAX_ABNORMAL_STATE_SUCCESS_RATE;
    public static long MAX_SP;
    public static byte MAX_SUBCLASS;
    public static byte BASE_SUBCLASS_LEVEL;
    public static byte MAX_SUBCLASS_LEVEL;
    public static int MAX_PVTSTORESELL_SLOTS_DWARF;
    public static int MAX_PVTSTORESELL_SLOTS_OTHER;
    public static int MAX_PVTSTOREBUY_SLOTS_DWARF;
    public static int MAX_PVTSTOREBUY_SLOTS_OTHER;
    public static int INVENTORY_MAXIMUM_NO_DWARF;
    public static int INVENTORY_MAXIMUM_DWARF;
    public static int INVENTORY_MAXIMUM_GM;
    public static int INVENTORY_MAXIMUM_QUEST_ITEMS;
    public static int WAREHOUSE_SLOTS_DWARF;
    public static int WAREHOUSE_SLOTS_NO_DWARF;
    public static int WAREHOUSE_SLOTS_CLAN;
    public static int ALT_FREIGHT_SLOTS;
    public static int ALT_FREIGHT_PRICE;
    public static boolean ALT_GAME_KARMA_PLAYER_CAN_BE_KILLED_IN_PEACEZONE;
    public static boolean ALT_GAME_KARMA_PLAYER_CAN_SHOP;
    public static boolean ALT_GAME_KARMA_PLAYER_CAN_TELEPORT;
    public static boolean ALT_GAME_KARMA_PLAYER_CAN_USE_GK;
    public static boolean ALT_GAME_KARMA_PLAYER_CAN_TRADE;
    public static boolean ALT_GAME_KARMA_PLAYER_CAN_USE_WAREHOUSE;
    public static int MAX_PERSONAL_FAME_POINTS;
    public static int FORTRESS_ZONE_FAME_TASK_FREQUENCY;
    public static int FORTRESS_ZONE_FAME_AQUIRE_POINTS;
    public static int CASTLE_ZONE_FAME_TASK_FREQUENCY;
    public static int CASTLE_ZONE_FAME_AQUIRE_POINTS;
    public static boolean FAME_FOR_DEAD_PLAYERS;
    public static boolean IS_CRAFTING_ENABLED;
    public static boolean CRAFT_MASTERWORK;
    public static int DWARF_RECIPE_LIMIT;
    public static int COMMON_RECIPE_LIMIT;
    public static boolean ALT_GAME_CREATION;
    public static double ALT_GAME_CREATION_SPEED;
    public static double ALT_GAME_CREATION_XP_RATE;
    public static double ALT_GAME_CREATION_RARE_XPSP_RATE;
    public static double ALT_GAME_CREATION_SP_RATE;
    public static boolean ALT_BLACKSMITH_USE_RECIPES;
    public static int ALT_CLAN_LEADER_DATE_CHANGE;
    public static String ALT_CLAN_LEADER_HOUR_CHANGE;
    public static boolean ALT_CLAN_LEADER_INSTANT_ACTIVATION;
    public static int ALT_CLAN_JOIN_DAYS;
    public static int ALT_CLAN_CREATE_DAYS;
    public static int ALT_CLAN_DISSOLVE_DAYS;
    public static int ALT_ALLY_JOIN_DAYS_WHEN_LEAVED;
    public static int ALT_ALLY_JOIN_DAYS_WHEN_DISMISSED;
    public static int ALT_ACCEPT_CLAN_DAYS_WHEN_DISMISSED;
    public static int ALT_CREATE_ALLY_DAYS_WHEN_DISSOLVED;
    public static int ALT_MAX_NUM_OF_CLANS_IN_ALLY;
    public static int ALT_CLAN_MEMBERS_FOR_WAR;
    public static boolean ALT_MEMBERS_CAN_WITHDRAW_FROM_CLANWH;
    public static boolean REMOVE_CASTLE_CIRCLETS;
    public static int ALT_PARTY_RANGE;
    public static int ALT_PARTY_RANGE2;
    public static boolean ALT_LEAVE_PARTY_LEADER;
    public static boolean INITIAL_EQUIPMENT_EVENT;
    public static long STARTING_ADENA;
    public static byte STARTING_LEVEL;
    public static int STARTING_SP;
    public static long MAX_ADENA;
    public static boolean AUTO_LOOT;
    public static boolean AUTO_LOOT_RAIDS;
    public static boolean AUTO_LOOT_SLOT_LIMIT;
    public static int LOOT_RAIDS_PRIVILEGE_INTERVAL;
    public static int LOOT_RAIDS_PRIVILEGE_CC_SIZE;
    public static List<Integer> AUTO_LOOT_ITEM_IDS;
    public static boolean ENABLE_KEYBOARD_MOVEMENT;
    public static int UNSTUCK_INTERVAL;
    public static int TELEPORT_WATCHDOG_TIMEOUT;
    public static int PLAYER_SPAWN_PROTECTION;
    public static int PLAYER_TELEPORT_PROTECTION;
    public static boolean RANDOM_RESPAWN_IN_TOWN_ENABLED;
    public static boolean OFFSET_ON_TELEPORT_ENABLED;
    public static int MAX_OFFSET_ON_TELEPORT;
    public static boolean PETITIONING_ALLOWED;
    public static int MAX_PETITIONS_PER_PLAYER;
    public static int MAX_PETITIONS_PENDING;
    public static boolean FREE_TELEPORTING;
    public static int DELETE_DAYS;
    public static String PARTY_XP_CUTOFF_METHOD;
    public static double PARTY_XP_CUTOFF_PERCENT;
    public static int PARTY_XP_CUTOFF_LEVEL;
    public static int[][] PARTY_XP_CUTOFF_GAPS;
    public static int[] PARTY_XP_CUTOFF_GAP_PERCENTS;
    public static boolean DISABLE_TUTORIAL;
    public static boolean EXPERTISE_PENALTY;
    public static boolean STORE_RECIPE_SHOPLIST;
    public static boolean STORE_UI_SETTINGS;
    public static String[] FORBIDDEN_NAMES;
    public static boolean SILENCE_MODE_EXCLUDE;
    public static boolean ALT_VALIDATE_TRIGGER_SKILLS;
   
    public static boolean NEVIT_ENABLED;
    public static int NEVIT_MAX_POINTS;
    public static int NEVIT_BONUS_EFFECT_TIME;
    public static int NEVIT_ADVENT_TIME;
    public static boolean NEVIT_IGNORE_ADVENT_TIME;
   
    // --------------------------------------------------
    // ClanHall Settings
    // --------------------------------------------------
    public static long CH_TELE_FEE_RATIO;
    public static int CH_TELE1_FEE;
    public static int CH_TELE2_FEE;
    public static long CH_ITEM_FEE_RATIO;
    public static int CH_ITEM1_FEE;
    public static int CH_ITEM2_FEE;
    public static int CH_ITEM3_FEE;
    public static long CH_MPREG_FEE_RATIO;
    public static int CH_MPREG1_FEE;
    public static int CH_MPREG2_FEE;
    public static int CH_MPREG3_FEE;
    public static int CH_MPREG4_FEE;
    public static int CH_MPREG5_FEE;
    public static long CH_HPREG_FEE_RATIO;
    public static int CH_HPREG1_FEE;
    public static int CH_HPREG2_FEE;
    public static int CH_HPREG3_FEE;
    public static int CH_HPREG4_FEE;
    public static int CH_HPREG5_FEE;
    public static int CH_HPREG6_FEE;
    public static int CH_HPREG7_FEE;
    public static int CH_HPREG8_FEE;
    public static int CH_HPREG9_FEE;
    public static int CH_HPREG10_FEE;
    public static int CH_HPREG11_FEE;
    public static int CH_HPREG12_FEE;
    public static int CH_HPREG13_FEE;
    public static long CH_EXPREG_FEE_RATIO;
    public static int CH_EXPREG1_FEE;
    public static int CH_EXPREG2_FEE;
    public static int CH_EXPREG3_FEE;
    public static int CH_EXPREG4_FEE;
    public static int CH_EXPREG5_FEE;
    public static int CH_EXPREG6_FEE;
    public static int CH_EXPREG7_FEE;
    public static long CH_SUPPORT_FEE_RATIO;
    public static int CH_SUPPORT1_FEE;
    public static int CH_SUPPORT2_FEE;
    public static int CH_SUPPORT3_FEE;
    public static int CH_SUPPORT4_FEE;
    public static int CH_SUPPORT5_FEE;
    public static int CH_SUPPORT6_FEE;
    public static int CH_SUPPORT7_FEE;
    public static int CH_SUPPORT8_FEE;
    public static long CH_CURTAIN_FEE_RATIO;
    public static int CH_CURTAIN1_FEE;
    public static int CH_CURTAIN2_FEE;
    public static long CH_FRONT_FEE_RATIO;
    public static int CH_FRONT1_FEE;
    public static int CH_FRONT2_FEE;
    public static boolean CH_BUFF_FREE;
    // --------------------------------------------------
    // Castle Settings
    // --------------------------------------------------
    public static long CS_TELE_FEE_RATIO;
    public static int CS_TELE1_FEE;
    public static int CS_TELE2_FEE;
    public static long CS_MPREG_FEE_RATIO;
    public static int CS_MPREG1_FEE;
    public static int CS_MPREG2_FEE;
    public static long CS_HPREG_FEE_RATIO;
    public static int CS_HPREG1_FEE;
    public static int CS_HPREG2_FEE;
    public static long CS_EXPREG_FEE_RATIO;
    public static int CS_EXPREG1_FEE;
    public static int CS_EXPREG2_FEE;
    public static long CS_SUPPORT_FEE_RATIO;
    public static int CS_SUPPORT1_FEE;
    public static int CS_SUPPORT2_FEE;
    public static List<Integer> SIEGE_HOUR_LIST;
    public static int OUTER_DOOR_UPGRADE_PRICE2;
    public static int OUTER_DOOR_UPGRADE_PRICE3;
    public static int OUTER_DOOR_UPGRADE_PRICE5;
    public static int INNER_DOOR_UPGRADE_PRICE2;
    public static int INNER_DOOR_UPGRADE_PRICE3;
    public static int INNER_DOOR_UPGRADE_PRICE5;
    public static int WALL_UPGRADE_PRICE2;
    public static int WALL_UPGRADE_PRICE3;
    public static int WALL_UPGRADE_PRICE5;
    public static int TRAP_UPGRADE_PRICE1;
    public static int TRAP_UPGRADE_PRICE2;
    public static int TRAP_UPGRADE_PRICE3;
    public static int TRAP_UPGRADE_PRICE4;
   
    // --------------------------------------------------
    // Fortress Settings
    // --------------------------------------------------
    public static long FS_TELE_FEE_RATIO;
    public static int FS_TELE1_FEE;
    public static int FS_TELE2_FEE;
    public static long FS_MPREG_FEE_RATIO;
    public static int FS_MPREG1_FEE;
    public static int FS_MPREG2_FEE;
    public static long FS_HPREG_FEE_RATIO;
    public static int FS_HPREG1_FEE;
    public static int FS_HPREG2_FEE;
    public static long FS_EXPREG_FEE_RATIO;
    public static int FS_EXPREG1_FEE;
    public static int FS_EXPREG2_FEE;
    public static long FS_SUPPORT_FEE_RATIO;
    public static int FS_SUPPORT1_FEE;
    public static int FS_SUPPORT2_FEE;
    public static int FS_BLOOD_OATH_COUNT;
    public static int FS_UPDATE_FRQ;
    public static int FS_MAX_SUPPLY_LEVEL;
    public static int FS_FEE_FOR_CASTLE;
    public static int FS_MAX_OWN_TIME;
   
    // --------------------------------------------------
    // Feature Settings
    // --------------------------------------------------
    public static int TAKE_FORT_POINTS;
    public static int LOOSE_FORT_POINTS;
    public static int TAKE_CASTLE_POINTS;
    public static int LOOSE_CASTLE_POINTS;
    public static int CASTLE_DEFENDED_POINTS;
    public static int FESTIVAL_WIN_POINTS;
    public static int HERO_POINTS;
    public static int ROYAL_GUARD_COST;
    public static int KNIGHT_UNIT_COST;
    public static int KNIGHT_REINFORCE_COST;
    public static int BALLISTA_POINTS;
    public static int BLOODALLIANCE_POINTS;
    public static int BLOODOATH_POINTS;
    public static int KNIGHTSEPAULETTE_POINTS;
    public static int REPUTATION_SCORE_PER_KILL;
    public static int JOIN_ACADEMY_MIN_REP_SCORE;
    public static int JOIN_ACADEMY_MAX_REP_SCORE;
    public static int RAID_RANKING_1ST;
    public static int RAID_RANKING_2ND;
    public static int RAID_RANKING_3RD;
    public static int RAID_RANKING_4TH;
    public static int RAID_RANKING_5TH;
    public static int RAID_RANKING_6TH;
    public static int RAID_RANKING_7TH;
    public static int RAID_RANKING_8TH;
    public static int RAID_RANKING_9TH;
    public static int RAID_RANKING_10TH;
    public static int RAID_RANKING_UP_TO_50TH;
    public static int RAID_RANKING_UP_TO_100TH;
    public static int CLAN_LEVEL_6_COST;
    public static int CLAN_LEVEL_7_COST;
    public static int CLAN_LEVEL_8_COST;
    public static int CLAN_LEVEL_9_COST;
    public static int CLAN_LEVEL_10_COST;
    public static int CLAN_LEVEL_11_COST;
    public static int CLAN_LEVEL_6_REQUIREMENT;
    public static int CLAN_LEVEL_7_REQUIREMENT;
    public static int CLAN_LEVEL_8_REQUIREMENT;
    public static int CLAN_LEVEL_9_REQUIREMENT;
    public static int CLAN_LEVEL_10_REQUIREMENT;
    public static int CLAN_LEVEL_11_REQUIREMENT;
    public static boolean ALLOW_WYVERN_ALWAYS;
    public static boolean ALLOW_WYVERN_DURING_SIEGE;
    public static boolean ALLOW_MOUNTS_DURING_SIEGE;
   
    // --------------------------------------------------
    // General Settings
    // --------------------------------------------------
    public static boolean EVERYBODY_HAS_ADMIN_RIGHTS;
    public static boolean SERVER_GMONLY;
    public static boolean GM_HERO_AURA;
    public static boolean GM_STARTUP_BUILDER_HIDE;
    public static boolean GM_STARTUP_INVULNERABLE;
    public static boolean GM_STARTUP_INVISIBLE;
    public static boolean GM_STARTUP_SILENCE;
    public static boolean GM_STARTUP_AUTO_LIST;
    public static boolean GM_STARTUP_DIET_MODE;
    public static boolean GM_ITEM_RESTRICTION;
    public static boolean GM_SKILL_RESTRICTION;
    public static boolean GM_TRADE_RESTRICTED_ITEMS;
    public static boolean GM_RESTART_FIGHTING;
    public static boolean GM_ANNOUNCER_NAME;
    public static boolean GM_CRITANNOUNCER_NAME;
    public static boolean GM_GIVE_SPECIAL_SKILLS;
    public static boolean GM_GIVE_SPECIAL_AURA_SKILLS;
    public static boolean GM_DEBUG_HTML_PATHS;
    public static boolean USE_SUPER_HASTE_AS_GM_SPEED;
    public static boolean LOG_CHAT;
    public static boolean LOG_AUTO_ANNOUNCEMENTS;
    public static boolean LOG_ITEMS;
    public static boolean LOG_ITEMS_SMALL_LOG;
    public static boolean LOG_ITEM_ENCHANTS;
    public static boolean LOG_SKILL_ENCHANTS;
    public static boolean GMAUDIT;
    public static boolean SKILL_CHECK_ENABLE;
    public static boolean SKILL_CHECK_REMOVE;
    public static boolean SKILL_CHECK_GM;
    public static boolean HTML_ACTION_CACHE_DEBUG;
    public static boolean PACKET_HANDLER_DEBUG;
    public static boolean DEVELOPER;
    public static boolean ALT_DEV_NO_HANDLERS;
    public static boolean ALT_DEV_NO_QUESTS;
    public static boolean ALT_DEV_NO_SPAWNS;
    public static boolean ALT_DEV_SHOW_QUESTS_LOAD_IN_LOGS;
    public static boolean ALT_DEV_SHOW_SCRIPTS_LOAD_IN_LOGS;
    public static int SCHEDULED_THREAD_POOL_COUNT;
    public static int THREADS_PER_SCHEDULED_THREAD_POOL;
    public static int INSTANT_THREAD_POOL_COUNT;
    public static int THREADS_PER_INSTANT_THREAD_POOL;
    public static int IO_PACKET_THREAD_CORE_SIZE;
    public static boolean DEADLOCK_DETECTOR;
    public static int DEADLOCK_CHECK_INTERVAL;
    public static boolean RESTART_ON_DEADLOCK;
    public static boolean ALLOW_DISCARDITEM;
    public static int AUTODESTROY_ITEM_AFTER;
    public static int HERB_AUTO_DESTROY_TIME;
    public static List<Integer> LIST_PROTECTED_ITEMS;
    public static boolean DATABASE_CLEAN_UP;
    public static int CHAR_DATA_STORE_INTERVAL;
    public static boolean LAZY_ITEMS_UPDATE;
    public static boolean UPDATE_ITEMS_ON_CHAR_STORE;
    public static boolean DESTROY_DROPPED_PLAYER_ITEM;
    public static boolean DESTROY_EQUIPABLE_PLAYER_ITEM;
    public static boolean DESTROY_ALL_ITEMS;
    public static boolean SAVE_DROPPED_ITEM;
    public static boolean EMPTY_DROPPED_ITEM_TABLE_AFTER_LOAD;
    public static int SAVE_DROPPED_ITEM_INTERVAL;
    public static boolean CLEAR_DROPPED_ITEM_TABLE;
    public static boolean AUTODELETE_INVALID_QUEST_DATA;
    public static boolean MULTIPLE_ITEM_DROP;
    public static boolean FORCE_INVENTORY_UPDATE;
    public static boolean LAZY_CACHE;
    public static boolean CACHE_CHAR_NAMES;
    public static int MIN_NPC_ANIMATION;
    public static int MAX_NPC_ANIMATION;
    public static int MIN_MONSTER_ANIMATION;
    public static int MAX_MONSTER_ANIMATION;
    public static boolean ENABLE_FALLING_DAMAGE;
    public static boolean GRIDS_ALWAYS_ON;
    public static int GRID_NEIGHBOR_TURNON_TIME;
    public static int GRID_NEIGHBOR_TURNOFF_TIME;
    public static boolean MOVE_BASED_KNOWNLIST;
    public static long KNOWNLIST_UPDATE_INTERVAL;
    public static int PEACE_ZONE_MODE;
    public static String DEFAULT_GLOBAL_CHAT;
    public static String DEFAULT_TRADE_CHAT;
    public static int MINIMUM_CHAT_LEVEL;
    public static boolean ALLOW_WAREHOUSE;
    public static boolean WAREHOUSE_CACHE;
    public static int WAREHOUSE_CACHE_TIME;
    public static boolean ALLOW_REFUND;
    public static boolean ALLOW_MAIL;
    public static boolean ALLOW_ATTACHMENTS;
    public static boolean ALLOW_WEAR;
    public static int WEAR_DELAY;
    public static int WEAR_PRICE;
    public static int INSTANCE_FINISH_TIME;
    public static boolean RESTORE_PLAYER_INSTANCE;
    public static boolean ALLOW_SUMMON_IN_INSTANCE;
    public static int EJECT_DEAD_PLAYER_TIME;
    public static boolean ALLOW_LOTTERY;
    public static boolean ALLOW_RACE;
    public static boolean ALLOW_WATER;
    public static boolean ALLOW_RENTPET;
    public static boolean ALLOW_FISHING;
    public static boolean ALLOW_BOAT;
    public static int BOAT_BROADCAST_RADIUS;
    public static boolean ALLOW_CURSED_WEAPONS;
    public static boolean ALLOW_MANOR;
    public static boolean SERVER_NEWS;
    public static boolean ENABLE_COMMUNITY_BOARD;
    public static String BBS_DEFAULT;
    public static boolean USE_SAY_FILTER;
    public static String CHAT_FILTER_CHARS;
    public static Set<ChatType> BAN_CHAT_CHANNELS;
    public static int ALT_OLY_START_TIME;
    public static int ALT_OLY_MIN;
    public static int ALT_OLY_MAX_BUFFS;
    public static long ALT_OLY_CPERIOD;
    public static long ALT_OLY_BATTLE;
    public static long ALT_OLY_WPERIOD;
    public static long ALT_OLY_VPERIOD;
    public static int ALT_OLY_START_POINTS;
    public static int ALT_OLY_WEEKLY_POINTS;
    public static int ALT_OLY_CLASSED;
    public static int ALT_OLY_NONCLASSED;
    public static int ALT_OLY_TEAMS;
    public static int ALT_OLY_REG_DISPLAY;
    public static int[][] ALT_OLY_CLASSED_REWARD;
    public static int[][] ALT_OLY_NONCLASSED_REWARD;
    public static int[][] ALT_OLY_TEAM_REWARD;
    public static int ALT_OLY_COMP_RITEM;
    public static int ALT_OLY_MIN_MATCHES;
    public static int ALT_OLY_GP_PER_POINT;
    public static int ALT_OLY_HERO_POINTS;
    public static int ALT_OLY_RANK1_POINTS;
    public static int ALT_OLY_RANK2_POINTS;
    public static int ALT_OLY_RANK3_POINTS;
    public static int ALT_OLY_RANK4_POINTS;
    public static int ALT_OLY_RANK5_POINTS;
    public static int ALT_OLY_MAX_POINTS;
    public static int ALT_OLY_DIVIDER_CLASSED;
    public static int ALT_OLY_DIVIDER_NON_CLASSED;
    public static int ALT_OLY_MAX_WEEKLY_MATCHES;
    public static int ALT_OLY_MAX_WEEKLY_MATCHES_NON_CLASSED;
    public static int ALT_OLY_MAX_WEEKLY_MATCHES_CLASSED;
    public static int ALT_OLY_MAX_WEEKLY_MATCHES_TEAM;
    public static boolean ALT_OLY_LOG_FIGHTS;
    public static boolean ALT_OLY_SHOW_MONTHLY_WINNERS;
    public static boolean ALT_OLY_ANNOUNCE_GAMES;
    public static List<Integer> LIST_OLY_RESTRICTED_ITEMS;
    public static int ALT_OLY_ENCHANT_LIMIT;
    public static int ALT_OLY_WAIT_TIME;
    public static boolean ALT_OLY_USE_CUSTOM_PERIOD_SETTINGS;
    public static String ALT_OLY_PERIOD;
    public static int ALT_OLY_PERIOD_MULTIPLIER;
    public static List<Integer> ALT_OLY_COMPETITION_DAYS;
    public static int ALT_MANOR_REFRESH_TIME;
    public static int ALT_MANOR_REFRESH_MIN;
    public static int ALT_MANOR_APPROVE_TIME;
    public static int ALT_MANOR_APPROVE_MIN;
    public static int ALT_MANOR_MAINTENANCE_MIN;
    public static boolean ALT_MANOR_SAVE_ALL_ACTIONS;
    public static int ALT_MANOR_SAVE_PERIOD_RATE;
    public static long ALT_LOTTERY_PRIZE;
    public static long ALT_LOTTERY_TICKET_PRICE;
    public static float ALT_LOTTERY_5_NUMBER_RATE;
    public static float ALT_LOTTERY_4_NUMBER_RATE;
    public static float ALT_LOTTERY_3_NUMBER_RATE;
    public static long ALT_LOTTERY_2_AND_1_NUMBER_PRIZE;
    public static boolean ALT_FISH_CHAMPIONSHIP_ENABLED;
    public static int ALT_FISH_CHAMPIONSHIP_REWARD_ITEM;
    public static int ALT_FISH_CHAMPIONSHIP_REWARD_1;
    public static int ALT_FISH_CHAMPIONSHIP_REWARD_2;
    public static int ALT_FISH_CHAMPIONSHIP_REWARD_3;
    public static int ALT_FISH_CHAMPIONSHIP_REWARD_4;
    public static int ALT_FISH_CHAMPIONSHIP_REWARD_5;
    public static boolean ALT_ITEM_AUCTION_ENABLED;
    public static int ALT_ITEM_AUCTION_EXPIRED_AFTER;
    public static long ALT_ITEM_AUCTION_TIME_EXTENDS_ON_BID;
    public static int FS_TIME_ATTACK;
    public static int FS_TIME_COOLDOWN;
    public static int FS_TIME_ENTRY;
    public static int FS_TIME_WARMUP;
    public static int FS_PARTY_MEMBER_COUNT;
    public static int RIFT_MIN_PARTY_SIZE;
    public static int RIFT_SPAWN_DELAY;
    public static int RIFT_MAX_JUMPS;
    public static int RIFT_AUTO_JUMPS_TIME_MIN;
    public static int RIFT_AUTO_JUMPS_TIME_MAX;
    public static float RIFT_BOSS_ROOM_TIME_MUTIPLY;
    public static int RIFT_ENTER_COST_RECRUIT;
    public static int RIFT_ENTER_COST_SOLDIER;
    public static int RIFT_ENTER_COST_OFFICER;
    public static int RIFT_ENTER_COST_CAPTAIN;
    public static int RIFT_ENTER_COST_COMMANDER;
    public static int RIFT_ENTER_COST_HERO;
    public static IllegalActionPunishmentType DEFAULT_PUNISH;
    public static int DEFAULT_PUNISH_PARAM;
    public static boolean ONLY_GM_ITEMS_FREE;
    public static boolean JAIL_IS_PVP;
    public static boolean JAIL_DISABLE_CHAT;
    public static boolean JAIL_DISABLE_TRANSACTION;
    public static boolean CUSTOM_NPC_DATA;
    public static boolean CUSTOM_TELEPORT_TABLE;
    public static boolean CUSTOM_SKILLS_LOAD;
    public static boolean CUSTOM_ITEMS_LOAD;
    public static boolean CUSTOM_MULTISELL_LOAD;
    public static boolean CUSTOM_BUYLIST_LOAD;
    public static int ALT_BIRTHDAY_GIFT;
    public static String ALT_BIRTHDAY_MAIL_SUBJECT;
    public static String ALT_BIRTHDAY_MAIL_TEXT;
    public static boolean ENABLE_BLOCK_CHECKER_EVENT;
    public static int MIN_BLOCK_CHECKER_TEAM_MEMBERS;
    public static boolean HBCE_FAIR_PLAY;
    public static boolean HELLBOUND_WITHOUT_QUEST;
    public static int PLAYER_MOVEMENT_BLOCK_TIME;
    public static int NORMAL_ENCHANT_COST_MULTIPLIER;
    public static int SAFE_ENCHANT_COST_MULTIPLIER;
    public static boolean BOTREPORT_ENABLE;
    public static String[] BOTREPORT_RESETPOINT_HOUR;
    public static long BOTREPORT_REPORT_DELAY;
    public static boolean BOTREPORT_ALLOW_REPORTS_FROM_SAME_CLAN_MEMBERS;
    public static boolean ENABLE_PRIME_SHOP;
    public static int PRIME_SHOP_ITEM_ID;
   
    // --------------------------------------------------
    // FloodProtector Settings
    // --------------------------------------------------
    public static FloodProtectorConfig FLOOD_PROTECTOR_USE_ITEM;
    public static FloodProtectorConfig FLOOD_PROTECTOR_ROLL_DICE;
    public static FloodProtectorConfig FLOOD_PROTECTOR_FIREWORK;
    public static FloodProtectorConfig FLOOD_PROTECTOR_ITEM_PET_SUMMON;
    public static FloodProtectorConfig FLOOD_PROTECTOR_HERO_VOICE;
    public static FloodProtectorConfig FLOOD_PROTECTOR_GLOBAL_CHAT;
    public static FloodProtectorConfig FLOOD_PROTECTOR_SUBCLASS;
    public static FloodProtectorConfig FLOOD_PROTECTOR_DROP_ITEM;
    public static FloodProtectorConfig FLOOD_PROTECTOR_SERVER_BYPASS;
    public static FloodProtectorConfig FLOOD_PROTECTOR_MULTISELL;
    public static FloodProtectorConfig FLOOD_PROTECTOR_TRANSACTION;
    public static FloodProtectorConfig FLOOD_PROTECTOR_MANUFACTURE;
    public static FloodProtectorConfig FLOOD_PROTECTOR_MANOR;
    public static FloodProtectorConfig FLOOD_PROTECTOR_SENDMAIL;
    public static FloodProtectorConfig FLOOD_PROTECTOR_CHARACTER_SELECT;
    public static FloodProtectorConfig FLOOD_PROTECTOR_ITEM_AUCTION;
   
    // --------------------------------------------------
    // NPC Settings
    // --------------------------------------------------
    public static boolean ANNOUNCE_MAMMON_SPAWN;
    public static boolean ALT_MOB_AGRO_IN_PEACEZONE;
    public static boolean ALT_ATTACKABLE_NPCS;
    public static boolean ALT_GAME_VIEWNPC;
    public static int MAX_AGGRO_RANGE;
    public static int MAX_DRIFT_RANGE;
    public static boolean SHOW_NPC_LVL;
    public static boolean SHOW_CREST_WITHOUT_QUEST;
    public static boolean ENABLE_RANDOM_ENCHANT_EFFECT;
    public static int MIN_NPC_LVL_DMG_PENALTY;
    public static Map<Integer, Float> NPC_DMG_PENALTY;
    public static Map<Integer, Float> NPC_CRIT_DMG_PENALTY;
    public static Map<Integer, Float> NPC_SKILL_DMG_PENALTY;
    public static int MIN_NPC_LVL_MAGIC_PENALTY;
    public static Map<Integer, Float> NPC_SKILL_CHANCE_PENALTY;
    public static int DECAY_TIME_TASK;
    public static int DEFAULT_CORPSE_TIME;
    public static int SPOILED_CORPSE_EXTEND_TIME;
    public static int CORPSE_CONSUME_SKILL_ALLOWED_TIME_BEFORE_DECAY;
    public static boolean GUARD_ATTACK_AGGRO_MOB;
    public static boolean ENABLE_GUARD_RETURN;
    public static boolean ALLOW_WYVERN_UPGRADER;
    public static List<Integer> LIST_PET_RENT_NPC;
    public static double RAID_HP_REGEN_MULTIPLIER;
    public static double RAID_MP_REGEN_MULTIPLIER;
    public static double RAID_PDEFENCE_MULTIPLIER;
    public static double RAID_MDEFENCE_MULTIPLIER;
    public static double RAID_PATTACK_MULTIPLIER;
    public static double RAID_MATTACK_MULTIPLIER;
    public static double RAID_MINION_RESPAWN_TIMER;
    public static Map<Integer, Integer> MINIONS_RESPAWN_TIME;
    public static float RAID_MIN_RESPAWN_MULTIPLIER;
    public static float RAID_MAX_RESPAWN_MULTIPLIER;
    public static boolean RAID_DISABLE_CURSE;
    public static boolean FORCE_DELETE_MINIONS;
    public static int RAID_CHAOS_TIME;
    public static int GRAND_CHAOS_TIME;
    public static int MINION_CHAOS_TIME;
    public static int INVENTORY_MAXIMUM_PET;
    public static double PET_HP_REGEN_MULTIPLIER;
    public static double PET_MP_REGEN_MULTIPLIER;
   
    // --------------------------------------------------
    // PvP Settings
    // --------------------------------------------------
    public static boolean KARMA_DROP_GM;
    public static boolean KARMA_AWARD_PK_KILL;
    public static int KARMA_PK_LIMIT;
    public static String KARMA_NONDROPPABLE_PET_ITEMS;
    public static String KARMA_NONDROPPABLE_ITEMS;
    public static int[] KARMA_LIST_NONDROPPABLE_PET_ITEMS;
    public static int[] KARMA_LIST_NONDROPPABLE_ITEMS;
    public static boolean ANTIFEED_ENABLE;
    public static boolean ANTIFEED_DUALBOX;
    public static boolean ANTIFEED_DISCONNECTED_AS_DUALBOX;
    public static int ANTIFEED_INTERVAL;
    public static boolean ANNOUNCE_GAINAK_SIEGE;
   
    // --------------------------------------------------
    // Rate Settings
    // --------------------------------------------------
    public static float RATE_XP;
    public static float RATE_SP;
    public static float RATE_PARTY_XP;
    public static float RATE_PARTY_SP;
    public static float RATE_HB_TRUST_INCREASE;
    public static float RATE_HB_TRUST_DECREASE;
    public static float RATE_EXTRACTABLE;
    public static int RATE_DROP_MANOR;
    public static float RATE_QUEST_DROP;
    public static float RATE_QUEST_REWARD;
    public static float RATE_QUEST_REWARD_XP;
    public static float RATE_QUEST_REWARD_SP;
    public static float RATE_QUEST_REWARD_ADENA;
    public static boolean RATE_QUEST_REWARD_USE_MULTIPLIERS;
    public static float RATE_QUEST_REWARD_POTION;
    public static float RATE_QUEST_REWARD_SCROLL;
    public static float RATE_QUEST_REWARD_RECIPE;
    public static float RATE_QUEST_REWARD_MATERIAL;
    public static float RATE_DEATH_DROP_AMOUNT_MULTIPLIER;
    public static float RATE_SPOIL_DROP_AMOUNT_MULTIPLIER;
    public static float RATE_HERB_DROP_AMOUNT_MULTIPLIER;
    public static float RATE_RAID_DROP_AMOUNT_MULTIPLIER;
    public static float RATE_DEATH_DROP_CHANCE_MULTIPLIER;
    public static float RATE_SPOIL_DROP_CHANCE_MULTIPLIER;
    public static float RATE_HERB_DROP_CHANCE_MULTIPLIER;
    public static float RATE_RAID_DROP_CHANCE_MULTIPLIER;
    public static Map<Integer, Float> RATE_DROP_AMOUNT_BY_ID;
    public static Map<Integer, Float> RATE_DROP_CHANCE_BY_ID;
    public static int DROP_MAX_OCCURRENCES_NORMAL;
    public static int DROP_MAX_OCCURRENCES_RAIDBOSS;
    public static int DROP_ADENA_MIN_LEVEL_DIFFERENCE;
    public static int DROP_ADENA_MAX_LEVEL_DIFFERENCE;
    public static double DROP_ADENA_MIN_LEVEL_GAP_CHANCE;
    public static int DROP_ITEM_MIN_LEVEL_DIFFERENCE;
    public static int DROP_ITEM_MAX_LEVEL_DIFFERENCE;
    public static double DROP_ITEM_MIN_LEVEL_GAP_CHANCE;
    public static float RATE_KARMA_LOST;
    public static float RATE_KARMA_EXP_LOST;
    public static float RATE_SIEGE_GUARDS_PRICE;
    public static float RATE_DROP_COMMON_HERBS;
    public static float RATE_DROP_HP_HERBS;
    public static float RATE_DROP_MP_HERBS;
    public static float RATE_DROP_SPECIAL_HERBS;
    public static int PLAYER_DROP_LIMIT;
    public static int PLAYER_RATE_DROP;
    public static int PLAYER_RATE_DROP_ITEM;
    public static int PLAYER_RATE_DROP_EQUIP;
    public static int PLAYER_RATE_DROP_EQUIP_WEAPON;
    public static float PET_XP_RATE;
    public static int PET_FOOD_RATE;
    public static float SINEATER_XP_RATE;
    public static int KARMA_DROP_LIMIT;
    public static int KARMA_RATE_DROP;
    public static int KARMA_RATE_DROP_ITEM;
    public static int KARMA_RATE_DROP_EQUIP;
    public static int KARMA_RATE_DROP_EQUIP_WEAPON;
   
    // --------------------------------------------------
    // Seven Signs Settings
    // --------------------------------------------------
    public static boolean ALT_GAME_CASTLE_DAWN;
    public static boolean ALT_GAME_CASTLE_DUSK;
    public static boolean ALT_GAME_REQUIRE_CLAN_CASTLE;
    public static int ALT_FESTIVAL_MIN_PLAYER;
    public static int ALT_MAXIMUM_PLAYER_CONTRIB;
    public static long ALT_FESTIVAL_MANAGER_START;
    public static long ALT_FESTIVAL_LENGTH;
    public static long ALT_FESTIVAL_CYCLE_LENGTH;
    public static long ALT_FESTIVAL_FIRST_SPAWN;
    public static long ALT_FESTIVAL_FIRST_SWARM;
    public static long ALT_FESTIVAL_SECOND_SPAWN;
    public static long ALT_FESTIVAL_SECOND_SWARM;
    public static long ALT_FESTIVAL_CHEST_SPAWN;
    public static double ALT_SIEGE_DAWN_GATES_PDEF_MULT;
    public static double ALT_SIEGE_DUSK_GATES_PDEF_MULT;
    public static double ALT_SIEGE_DAWN_GATES_MDEF_MULT;
    public static double ALT_SIEGE_DUSK_GATES_MDEF_MULT;
    public static boolean ALT_STRICT_SEVENSIGNS;
    public static boolean ALT_SEVENSIGNS_LAZY_UPDATE;
    public static int SSQ_DAWN_TICKET_QUANTITY;
    public static int SSQ_DAWN_TICKET_PRICE;
    public static int SSQ_DAWN_TICKET_BUNDLE;
    public static int SSQ_MANORS_AGREEMENT_ID;
    public static int SSQ_JOIN_DAWN_ADENA_FEE;
   
    // --------------------------------------------------
    // Server Settings
    // --------------------------------------------------
    public static int PORT_GAME;
    public static int PORT_LOGIN;
    public static String LOGIN_BIND_ADDRESS;
    public static int LOGIN_TRY_BEFORE_BAN;
    public static int LOGIN_BLOCK_AFTER_BAN;
    public static String GAMESERVER_HOSTNAME;
    public static String DATABASE_DRIVER;
    public static String DATABASE_URL;
    public static String DATABASE_LOGIN;
    public static String DATABASE_PASSWORD;
    public static int DATABASE_MAX_CONNECTIONS;
    public static int DATABASE_MAX_IDLE_TIME;
    public static boolean BACKUP_DATABASE;
    public static String MYSQL_BIN_PATH;
    public static String BACKUP_PATH;
    public static int BACKUP_DAYS;
    public static int MAXIMUM_ONLINE_USERS;
    public static Pattern CHARNAME_TEMPLATE_PATTERN;
    public static String PET_NAME_TEMPLATE;
    public static String CLAN_NAME_TEMPLATE;
    public static int MAX_CHARACTERS_NUMBER_PER_ACCOUNT;
    public static File DATAPACK_ROOT;
    public static boolean ACCEPT_ALTERNATE_ID;
    public static int REQUEST_ID;
    public static boolean RESERVE_HOST_ON_LOGIN = false;
    public static List<Integer> PROTOCOL_LIST;
    public static int SERVER_LIST_TYPE;
    public static int SERVER_LIST_AGE;
    public static boolean SERVER_LIST_BRACKET;
    public static boolean LOGIN_SERVER_SCHEDULE_RESTART;
    public static long LOGIN_SERVER_SCHEDULE_RESTART_TIME;
    public static boolean SERVER_RESTART_SCHEDULE_ENABLED;
    public static boolean SERVER_RESTART_SCHEDULE_MESSAGE;
    public static int SERVER_RESTART_SCHEDULE_COUNTDOWN;
    public static String[] SERVER_RESTART_SCHEDULE;
   
    // --------------------------------------------------
    // MMO Settings
    // --------------------------------------------------
    public static int MMO_SELECTOR_SLEEP_TIME;
    public static int MMO_MAX_SEND_PER_PASS;
    public static int MMO_MAX_READ_PER_PASS;
    public static int MMO_HELPER_BUFFER_COUNT;
    public static boolean MMO_TCP_NODELAY;
   
    // --------------------------------------------------
    // Vitality Settings
    // --------------------------------------------------
    public static boolean ENABLE_VITALITY;
    public static boolean RECOVER_VITALITY_ON_RECONNECT;
    public static boolean ENABLE_DROP_VITALITY_HERBS;
    public static float RATE_VITALITY_LEVEL_1;
    public static float RATE_VITALITY_LEVEL_2;
    public static float RATE_VITALITY_LEVEL_3;
    public static float RATE_VITALITY_LEVEL_4;
    public static float RATE_DROP_VITALITY_HERBS;
    public static float RATE_RECOVERY_VITALITY_PEACE_ZONE;
    public static float RATE_VITALITY_LOST;
    public static float RATE_VITALITY_GAIN;
    public static float RATE_RECOVERY_ON_RECONNECT;
    public static int STARTING_VITALITY_POINTS;
    public static boolean RAIDBOSS_USE_VITALITY;
   
    // --------------------------------------------------
    // No classification assigned to the following yet
    // --------------------------------------------------
    public static int MAX_ITEM_IN_PACKET;
    public static int GAME_SERVER_LOGIN_PORT;
    public static String GAME_SERVER_LOGIN_HOST;
    public static List<String> GAME_SERVER_SUBNETS;
    public static List<String> GAME_SERVER_HOSTS;
    public static int PVP_NORMAL_TIME;
    public static int PVP_PVP_TIME;
   
    public enum IdFactoryType
    {
        BitSet,
        Stack
    }
   
    public static IdFactoryType IDFACTORY_TYPE;
    public static boolean BAD_ID_CHECKING;
   
    public static double ENCHANT_CHANCE_ELEMENT_STONE;
    public static double ENCHANT_CHANCE_ELEMENT_CRYSTAL;
    public static double ENCHANT_CHANCE_ELEMENT_JEWEL;
    public static double ENCHANT_CHANCE_ELEMENT_ENERGY;
    public static int[] ENCHANT_BLACKLIST;
    public static boolean DISABLE_OVER_ENCHANTING;
    public static int AUGMENTATION_NG_SKILL_CHANCE;
    public static int AUGMENTATION_NG_GLOW_CHANCE;
    public static int AUGMENTATION_MID_SKILL_CHANCE;
    public static int AUGMENTATION_MID_GLOW_CHANCE;
    public static int AUGMENTATION_HIGH_SKILL_CHANCE;
    public static int AUGMENTATION_HIGH_GLOW_CHANCE;
    public static int AUGMENTATION_TOP_SKILL_CHANCE;
    public static int AUGMENTATION_TOP_GLOW_CHANCE;
    public static int AUGMENTATION_BASESTAT_CHANCE;
    public static int AUGMENTATION_ACC_SKILL_CHANCE;
    public static boolean RETAIL_LIKE_AUGMENTATION;
    public static int[] RETAIL_LIKE_AUGMENTATION_NG_CHANCE;
    public static int[] RETAIL_LIKE_AUGMENTATION_MID_CHANCE;
    public static int[] RETAIL_LIKE_AUGMENTATION_HIGH_CHANCE;
    public static int[] RETAIL_LIKE_AUGMENTATION_TOP_CHANCE;
    public static boolean RETAIL_LIKE_AUGMENTATION_ACCESSORY;
    public static int[] AUGMENTATION_BLACKLIST;
    public static boolean ALT_ALLOW_AUGMENT_PVP_ITEMS;
    public static double HP_REGEN_MULTIPLIER;
    public static double MP_REGEN_MULTIPLIER;
    public static double CP_REGEN_MULTIPLIER;
    public static boolean TELNET_ENABLED;
    public static String TELNET_PASSWORD;
    public static String TELNET_HOSTNAME;
    public static List<String> TELNET_HOSTS;
    public static int TELNET_PORT;
    public static boolean SHOW_LICENCE;
    public static boolean ACCEPT_NEW_GAMESERVER;
    public static int SERVER_ID;
    public static byte[] HEX_ID;
    public static boolean AUTO_CREATE_ACCOUNTS;
    public static boolean FLOOD_PROTECTION;
    public static int FAST_CONNECTION_LIMIT;
    public static int NORMAL_CONNECTION_TIME;
    public static int FAST_CONNECTION_TIME;
    public static int MAX_CONNECTION_PER_IP;
   
    // GrandBoss Settings
   
    // Antharas
    public static int ANTHARAS_WAIT_TIME;
    public static int ANTHARAS_SPAWN_INTERVAL;
    public static int ANTHARAS_SPAWN_RANDOM;
   
    // Valakas
    public static int VALAKAS_WAIT_TIME;
    public static int VALAKAS_SPAWN_INTERVAL;
    public static int VALAKAS_SPAWN_RANDOM;
   
    // Baium
    public static int BAIUM_SPAWN_INTERVAL;
    public static int BAIUM_SPAWN_RANDOM;
   
    // Core
    public static int CORE_SPAWN_INTERVAL;
    public static int CORE_SPAWN_RANDOM;
   
    // Offen
    public static int ORFEN_SPAWN_INTERVAL;
    public static int ORFEN_SPAWN_RANDOM;
   
    // Queen Ant
    public static int QUEEN_ANT_SPAWN_INTERVAL;
    public static int QUEEN_ANT_SPAWN_RANDOM;
   
    // Beleth
    public static int BELETH_MIN_PLAYERS;
    public static int BELETH_SPAWN_INTERVAL;
    public static int BELETH_SPAWN_RANDOM;
   
    // Gracia Seeds Settings
    public static int SOD_TIAT_KILL_COUNT;
    public static long SOD_STAGE_2_LENGTH;
   
    // Tiat
    public static int MIN_TIAT_PLAYERS;
    public static int MAX_TIAT_PLAYERS;
    public static int MIN_TIAT_LEVEL;
   
    // Ekimus
    public static int SOI_EKIMUS_KILL_COUNT;
    public static int EROSION_ATTACK_MIN_PLAYERS;
    public static int EROSION_ATTACK_MAX_PLAYERS;
    public static int EROSION_DEFENCE_MIN_PLAYERS;
    public static int EROSION_DEFENCE_MAX_PLAYERS;
    public static int HEART_ATTACK_MIN_PLAYERS;
    public static int HEART_ATTACK_MAX_PLAYERS;
    public static int HEART_DEFENCE_MIN_PLAYERS;
    public static int HEART_DEFENCE_MAX_PLAYERS;
   
    // chatfilter
    public static List<String> FILTER_LIST;
   
    // Conquerable Halls Settings
    public static int CHS_CLAN_MINLEVEL;
    public static int CHS_MAX_ATTACKERS;
    public static int CHS_MAX_FLAGS_PER_CLAN;
    public static boolean CHS_ENABLE_FAME;
    public static int CHS_FAME_AMOUNT;
    public static int CHS_FAME_FREQUENCY;
   
    // --------------------------------------------------
    // GeoEngine
    // --------------------------------------------------
   
    /** Geodata */
    public static String GEODATA_PATH;
    public static int COORD_SYNCHRONIZE;
   
    /** Path checking */
    public static int PART_OF_CHARACTER_HEIGHT;
    public static int MAX_OBSTACLE_HEIGHT;
   
    /** Path finding */
    public static boolean PATHFINDING;
    public static String PATHFIND_BUFFERS;
    public static int BASE_WEIGHT;
    public static int DIAGONAL_WEIGHT;
    public static int HEURISTIC_WEIGHT;
    public static int OBSTACLE_MULTIPLIER;
    public static int MAX_ITERATIONS;
   
    // --------------------------------------------------
    // Custom Settings
    // --------------------------------------------------
    public static boolean CHAMPION_ENABLE;
    public static boolean CHAMPION_PASSIVE;
    public static int CHAMPION_FREQUENCY;
    public static String CHAMP_TITLE;
    public static boolean SHOW_CHAMPION_AURA;
    public static int CHAMP_MIN_LVL;
    public static int CHAMP_MAX_LVL;
    public static int CHAMPION_HP;
    public static float CHAMPION_REWARDS_EXP_SP;
    public static float CHAMPION_REWARDS_CHANCE;
    public static float CHAMPION_REWARDS_AMOUNT;
    public static float CHAMPION_ADENAS_REWARDS_CHANCE;
    public static float CHAMPION_ADENAS_REWARDS_AMOUNT;
    public static float CHAMPION_HP_REGEN;
    public static float CHAMPION_ATK;
    public static float CHAMPION_SPD_ATK;
    public static int CHAMPION_REWARD_LOWER_LVL_ITEM_CHANCE;
    public static int CHAMPION_REWARD_HIGHER_LVL_ITEM_CHANCE;
    public static int CHAMPION_REWARD_ID;
    public static int CHAMPION_REWARD_QTY;
    public static boolean CHAMPION_ENABLE_VITALITY;
    public static boolean CHAMPION_ENABLE_IN_INSTANCES;
    public static boolean TVT_EVENT_ENABLED;
    public static boolean TVT_EVENT_IN_INSTANCE;
    public static int TVT_EVENT_INSTANCE_ID;
    public static String[] TVT_EVENT_INTERVAL;
    public static int TVT_EVENT_PARTICIPATION_TIME;
    public static int TVT_EVENT_RUNNING_TIME;
    public static int TVT_EVENT_PARTICIPATION_NPC_ID;
    public static int[] TVT_EVENT_PARTICIPATION_NPC_COORDINATES = new int[4];
    public static int[] TVT_EVENT_PARTICIPATION_FEE = new int[2];
    public static int TVT_EVENT_MIN_PLAYERS_IN_TEAMS;
    public static int TVT_EVENT_MAX_PLAYERS_IN_TEAMS;
    public static int TVT_EVENT_RESPAWN_TELEPORT_DELAY;
    public static int TVT_EVENT_START_LEAVE_TELEPORT_DELAY;
    public static String TVT_EVENT_TEAM_1_NAME;
    public static int[] TVT_EVENT_TEAM_1_COORDINATES = new int[3];
    public static String TVT_EVENT_TEAM_2_NAME;
    public static int[] TVT_EVENT_TEAM_2_COORDINATES = new int[3];
    public static List<int[]> TVT_EVENT_REWARDS;
    public static boolean TVT_EVENT_TARGET_TEAM_MEMBERS_ALLOWED;
    public static boolean TVT_EVENT_SCROLL_ALLOWED;
    public static boolean TVT_EVENT_POTIONS_ALLOWED;
    public static boolean TVT_EVENT_SUMMON_BY_ITEM_ALLOWED;
    public static List<Integer> TVT_DOORS_IDS_TO_OPEN;
    public static List<Integer> TVT_DOORS_IDS_TO_CLOSE;
    public static boolean TVT_REWARD_TEAM_TIE;
    public static byte TVT_EVENT_MIN_LVL;
    public static byte TVT_EVENT_MAX_LVL;
    public static int TVT_EVENT_EFFECTS_REMOVAL;
    public static Map<Integer, Integer> TVT_EVENT_FIGHTER_BUFFS;
    public static Map<Integer, Integer> TVT_EVENT_MAGE_BUFFS;
    public static int TVT_EVENT_MAX_PARTICIPANTS_PER_IP;
    public static boolean TVT_ALLOW_VOICED_COMMAND;
    public static boolean ALLOW_WEDDING;
    public static int WEDDING_PRICE;
    public static boolean WEDDING_PUNISH_INFIDELITY;
    public static boolean WEDDING_TELEPORT;
    public static int WEDDING_TELEPORT_PRICE;
    public static int WEDDING_TELEPORT_DURATION;
    public static boolean WEDDING_SAMESEX;
    public static boolean WEDDING_FORMALWEAR;
    public static int WEDDING_DIVORCE_COSTS;
    public static boolean HELLBOUND_STATUS;
    public static boolean BANKING_SYSTEM_ENABLED;
    public static int BANKING_SYSTEM_GOLDBARS;
    public static int BANKING_SYSTEM_ADENA;
    public static boolean ENABLE_WAREHOUSESORTING_CLAN;
    public static boolean ENABLE_WAREHOUSESORTING_PRIVATE;
    public static boolean ENABLE_NPC_STAT_MULTIPIERS;
    public static double MONSTER_HP_MULTIPLIER;
    public static double MONSTER_MP_MULTIPLIER;
    public static double MONSTER_PATK_MULTIPLIER;
    public static double MONSTER_MATK_MULTIPLIER;
    public static double MONSTER_PDEF_MULTIPLIER;
    public static double MONSTER_MDEF_MULTIPLIER;
    public static double MONSTER_AGRRO_RANGE_MULTIPLIER;
    public static double MONSTER_CLAN_HELP_RANGE_MULTIPLIER;
    public static double RAIDBOSS_HP_MULTIPLIER;
    public static double RAIDBOSS_MP_MULTIPLIER;
    public static double RAIDBOSS_PATK_MULTIPLIER;
    public static double RAIDBOSS_MATK_MULTIPLIER;
    public static double RAIDBOSS_PDEF_MULTIPLIER;
    public static double RAIDBOSS_MDEF_MULTIPLIER;
    public static double RAIDBOSS_AGRRO_RANGE_MULTIPLIER;
    public static double RAIDBOSS_CLAN_HELP_RANGE_MULTIPLIER;
    public static double GUARD_HP_MULTIPLIER;
    public static double GUARD_MP_MULTIPLIER;
    public static double GUARD_PATK_MULTIPLIER;
    public static double GUARD_MATK_MULTIPLIER;
    public static double GUARD_PDEF_MULTIPLIER;
    public static double GUARD_MDEF_MULTIPLIER;
    public static double GUARD_AGRRO_RANGE_MULTIPLIER;
    public static double GUARD_CLAN_HELP_RANGE_MULTIPLIER;
    public static double DEFENDER_HP_MULTIPLIER;
    public static double DEFENDER_MP_MULTIPLIER;
    public static double DEFENDER_PATK_MULTIPLIER;
    public static double DEFENDER_MATK_MULTIPLIER;
    public static double DEFENDER_PDEF_MULTIPLIER;
    public static double DEFENDER_MDEF_MULTIPLIER;
    public static double DEFENDER_AGRRO_RANGE_MULTIPLIER;
    public static double DEFENDER_CLAN_HELP_RANGE_MULTIPLIER;
    public static boolean OFFLINE_TRADE_ENABLE;
    public static boolean OFFLINE_CRAFT_ENABLE;
    public static boolean OFFLINE_MODE_IN_PEACE_ZONE;
    public static boolean OFFLINE_MODE_NO_DAMAGE;
    public static boolean RESTORE_OFFLINERS;
    public static int OFFLINE_MAX_DAYS;
    public static boolean OFFLINE_DISCONNECT_FINISHED;
    public static boolean OFFLINE_SET_NAME_COLOR;
    public static int OFFLINE_NAME_COLOR;
    public static boolean OFFLINE_FAME;
    public static boolean STORE_OFFLINE_TRADE_IN_REALTIME;
    public static boolean DISPLAY_SERVER_TIME;
    public static int BUFFER_MAX_SCHEMES;
    public static int BUFFER_STATIC_BUFF_COST;
    public static boolean WELCOME_MESSAGE_ENABLED;
    public static String WELCOME_MESSAGE_TEXT;
    public static int WELCOME_MESSAGE_TIME;
    public static boolean ANNOUNCE_PK_PVP;
    public static boolean ANNOUNCE_PK_PVP_NORMAL_MESSAGE;
    public static String ANNOUNCE_PK_MSG;
    public static String ANNOUNCE_PVP_MSG;
    public static boolean REWARD_PVP_ITEM;
    public static int REWARD_PVP_ITEM_ID;
    public static int REWARD_PVP_ITEM_AMOUNT;
    public static boolean REWARD_PVP_ITEM_MESSAGE;
    public static boolean REWARD_PK_ITEM;
    public static int REWARD_PK_ITEM_ID;
    public static int REWARD_PK_ITEM_AMOUNT;
    public static boolean REWARD_PK_ITEM_MESSAGE;
    public static boolean DISABLE_REWARDS_IN_INSTANCES;
    public static boolean DISABLE_REWARDS_IN_PVP_ZONES;
    public static boolean PVP_COLOR_SYSTEM_ENABLED;
    public static int PVP_AMOUNT1;
    public static int PVP_AMOUNT2;
    public static int PVP_AMOUNT3;
    public static int PVP_AMOUNT4;
    public static int PVP_AMOUNT5;
    public static int NAME_COLOR_FOR_PVP_AMOUNT1;
    public static int NAME_COLOR_FOR_PVP_AMOUNT2;
    public static int NAME_COLOR_FOR_PVP_AMOUNT3;
    public static int NAME_COLOR_FOR_PVP_AMOUNT4;
    public static int NAME_COLOR_FOR_PVP_AMOUNT5;
    public static String TITLE_FOR_PVP_AMOUNT1;
    public static String TITLE_FOR_PVP_AMOUNT2;
    public static String TITLE_FOR_PVP_AMOUNT3;
    public static String TITLE_FOR_PVP_AMOUNT4;
    public static String TITLE_FOR_PVP_AMOUNT5;
    public static boolean CHAT_ADMIN;
    public static boolean MULTILANG_ENABLE;
    public static List<String> MULTILANG_ALLOWED = new ArrayList<>();
    public static String MULTILANG_DEFAULT;
    public static boolean MULTILANG_VOICED_ALLOW;
    public static boolean MULTILANG_SM_ENABLE;
    public static List<String> MULTILANG_SM_ALLOWED = new ArrayList<>();
    public static boolean MULTILANG_NS_ENABLE;
    public static List<String> MULTILANG_NS_ALLOWED = new ArrayList<>();
    public static boolean L2WALKER_PROTECTION;
    public static int DUALBOX_CHECK_MAX_PLAYERS_PER_IP;
    public static int DUALBOX_CHECK_MAX_OLYMPIAD_PARTICIPANTS_PER_IP;
    public static int DUALBOX_CHECK_MAX_L2EVENT_PARTICIPANTS_PER_IP;
    public static boolean DUALBOX_COUNT_OFFLINE_TRADERS;
    public static Map<Integer, Integer> DUALBOX_CHECK_WHITELIST;
    public static boolean ALLOW_CHANGE_PASSWORD;
    public static boolean ALLOW_HUMAN;
    public static boolean ALLOW_ELF;
    public static boolean ALLOW_DARKELF;
    public static boolean ALLOW_ORC;
    public static boolean ALLOW_DWARF;
    public static boolean ALLOW_KAMAEL;
    public static boolean AUTO_POTIONS_ENABLED;
    public static boolean AUTO_POTIONS_IN_OLYMPIAD;
    public static int AUTO_POTION_MIN_LVL;
    public static boolean AUTO_CP_ENABLED;
    public static boolean AUTO_HP_ENABLED;
    public static boolean AUTO_MP_ENABLED;
    public static int AUTO_CP_PERCENTAGE;
    public static int AUTO_HP_PERCENTAGE;
    public static int AUTO_MP_PERCENTAGE;
    public static List<Integer> AUTO_CP_ITEM_IDS;
    public static List<Integer> AUTO_HP_ITEM_IDS;
    public static List<Integer> AUTO_MP_ITEM_IDS;
    public static boolean CUSTOM_STARTING_LOC;
    public static int CUSTOM_STARTING_LOC_X;
    public static int CUSTOM_STARTING_LOC_Y;
    public static int CUSTOM_STARTING_LOC_Z;
    public static int SHOP_MIN_RANGE_FROM_NPC;
    public static int SHOP_MIN_RANGE_FROM_PLAYER;
    public static boolean ENABLE_RANDOM_MONSTER_SPAWNS;
    public static int MOB_MIN_SPAWN_RANGE;
    public static int MOB_MAX_SPAWN_RANGE;
    public static List<Integer> MOBS_LIST_NOT_RANDOM;
    public static boolean CUSTOM_CB_ENABLED;
    public static int COMMUNITYBOARD_CURRENCY;
    public static boolean COMMUNITYBOARD_ENABLE_MULTISELLS;
    public static boolean COMMUNITYBOARD_ENABLE_TELEPORTS;
    public static boolean COMMUNITYBOARD_ENABLE_BUFFS;
    public static boolean COMMUNITYBOARD_ENABLE_HEAL;
    public static int COMMUNITYBOARD_TELEPORT_PRICE;
    public static int COMMUNITYBOARD_BUFF_PRICE;
    public static int COMMUNITYBOARD_HEAL_PRICE;
    public static boolean COMMUNITYBOARD_COMBAT_DISABLED;
    public static boolean COMMUNITYBOARD_KARMA_DISABLED;
    public static boolean COMMUNITYBOARD_CAST_ANIMATIONS;
    public static boolean COMMUNITY_PREMIUM_SYSTEM_ENABLED;
    public static int COMMUNITY_PREMIUM_COIN_ID;
    public static int COMMUNITY_PREMIUM_PRICE_PER_DAY;
    public static List<Integer> COMMUNITY_AVAILABLE_BUFFS;
    public static Map<String, Location> COMMUNITY_AVAILABLE_TELEPORTS;
    public static boolean FACTION_SYSTEM_ENABLED;
    public static Location FACTION_STARTING_LOCATION;
    public static int FACTION_MANAGER_NPCID;
    public static Location FACTION_MANAGER_LOCATION;
    public static Location FACTION_GOOD_BASE_LOCATION;
    public static Location FACTION_EVIL_BASE_LOCATION;
    public static String FACTION_GOOD_TEAM_NAME;
    public static String FACTION_EVIL_TEAM_NAME;
    public static int FACTION_GOOD_NAME_COLOR;
    public static int FACTION_EVIL_NAME_COLOR;
    public static boolean FACTION_GUARDS_ENABLED;
    public static int FACTION_GOOD_GUARD_NPCID;
    public static int FACTION_EVIL_GUARD_NPCID;
    public static boolean FACTION_RESPAWN_AT_BASE;
    public static boolean FACTION_AUTO_NOBLESS;
    public static boolean FACTION_SPECIFIC_CHAT;
    public static boolean FACTION_BALANCE_ONLINE_PLAYERS;
    public static int FACTION_BALANCE_PLAYER_EXCEED_LIMIT;
    public static boolean FAKE_PLAYERS_ENABLED;
    public static boolean FAKE_PLAYER_CHAT;
    public static boolean FAKE_PLAYER_USE_SHOTS;
    public static boolean FAKE_PLAYER_KILL_PVP;
    public static boolean FAKE_PLAYER_KILL_KARMA;
    public static boolean FAKE_PLAYER_AGGRO_MONSTERS;
    public static boolean FAKE_PLAYER_AGGRO_PLAYERS;
    public static boolean FAKE_PLAYER_AGGRO_FPC;
    public static boolean FAKE_PLAYER_CAN_DROP_ITEMS;
    public static boolean FAKE_PLAYER_CAN_PICKUP;
    public static boolean ENABLE_FIND_PVP;
    public static boolean PREMIUM_SYSTEM_ENABLED;
    public static float PREMIUM_RATE_XP;
    public static float PREMIUM_RATE_SP;
    public static Map<Integer, Float> PREMIUM_RATE_DROP_ITEMS_ID;
    public static float PREMIUM_RATE_DROP_CHANCE;
    public static float PREMIUM_RATE_DROP_AMOUNT;
    public static float PREMIUM_RATE_SPOIL_CHANCE;
    public static float PREMIUM_RATE_SPOIL_AMOUNT;
    public static Map<Integer, Float> PREMIUM_RATE_DROP_CHANCE_BY_ID;
    public static Map<Integer, Float> PREMIUM_RATE_DROP_AMOUNT_BY_ID;
    public static boolean SELLBUFF_ENABLED;
    public static int SELLBUFF_MP_MULTIPLER;
    public static int SELLBUFF_PAYMENT_ID;
    public static long SELLBUFF_MIN_PRICE;
    public static long SELLBUFF_MAX_PRICE;
    public static int SELLBUFF_MAX_BUFFS;
    public static boolean ALLOW_NETWORK_VOTE_REWARD;
    public static String NETWORK_SERVER_LINK;
    public static int NETWORK_VOTES_DIFFERENCE;
    public static int NETWORK_REWARD_CHECK_TIME;
    public static Map<Integer, Integer> NETWORK_REWARD = new HashMap<>();
    public static int NETWORK_DUALBOXES_ALLOWED;
    public static boolean ALLOW_NETWORK_GAME_SERVER_REPORT;
    public static boolean ALLOW_TOPZONE_VOTE_REWARD;
    public static String TOPZONE_SERVER_LINK;
    public static int TOPZONE_VOTES_DIFFERENCE;
    public static int TOPZONE_REWARD_CHECK_TIME;
    public static Map<Integer, Integer> TOPZONE_REWARD = new HashMap<>();
    public static int TOPZONE_DUALBOXES_ALLOWED;
    public static boolean ALLOW_TOPZONE_GAME_SERVER_REPORT;
    public static boolean ALLOW_HOPZONE_VOTE_REWARD;
    public static String HOPZONE_SERVER_LINK;
    public static int HOPZONE_VOTES_DIFFERENCE;
    public static int HOPZONE_REWARD_CHECK_TIME;
    public static Map<Integer, Integer> HOPZONE_REWARD = new HashMap<>();
    public static int HOPZONE_DUALBOXES_ALLOWED;
    public static boolean ALLOW_HOPZONE_GAME_SERVER_REPORT;
   
    /**
     * This class initializes all global variables for configuration.<br>
     * If the key doesn't appear in config file, a default value is set by this class. {@link #GAME_CONFIG_FILE} (config file) for configuring your server.
     */
    public static void load()
    {
        if (Server.serverMode == Server.MODE_GAMESERVER)
        {
            FLOOD_PROTECTOR_USE_ITEM = new FloodProtectorConfig("UseItemFloodProtector");
            FLOOD_PROTECTOR_ROLL_DICE = new FloodProtectorConfig("RollDiceFloodProtector");
            FLOOD_PROTECTOR_FIREWORK = new FloodProtectorConfig("FireworkFloodProtector");
            FLOOD_PROTECTOR_ITEM_PET_SUMMON = new FloodProtectorConfig("ItemPetSummonFloodProtector");
            FLOOD_PROTECTOR_HERO_VOICE = new FloodProtectorConfig("HeroVoiceFloodProtector");
            FLOOD_PROTECTOR_GLOBAL_CHAT = new FloodProtectorConfig("GlobalChatFloodProtector");
            FLOOD_PROTECTOR_SUBCLASS = new FloodProtectorConfig("SubclassFloodProtector");
            FLOOD_PROTECTOR_DROP_ITEM = new FloodProtectorConfig("DropItemFloodProtector");
            FLOOD_PROTECTOR_SERVER_BYPASS = new FloodProtectorConfig("ServerBypassFloodProtector");
            FLOOD_PROTECTOR_MULTISELL = new FloodProtectorConfig("MultiSellFloodProtector");
            FLOOD_PROTECTOR_TRANSACTION = new FloodProtectorConfig("TransactionFloodProtector");
            FLOOD_PROTECTOR_MANUFACTURE = new FloodProtectorConfig("ManufactureFloodProtector");
            FLOOD_PROTECTOR_MANOR = new FloodProtectorConfig("ManorFloodProtector");
            FLOOD_PROTECTOR_SENDMAIL = new FloodProtectorConfig("SendMailFloodProtector");
            FLOOD_PROTECTOR_CHARACTER_SELECT = new FloodProtectorConfig("CharacterSelectFloodProtector");
            FLOOD_PROTECTOR_ITEM_AUCTION = new FloodProtectorConfig("ItemAuctionFloodProtector");
           
            final PropertiesParser serverSettings = new PropertiesParser(GAME_CONFIG_FILE);
           
            GAMESERVER_HOSTNAME = serverSettings.getString("GameserverHostname", "0.0.0.0");
            PORT_GAME = serverSettings.getInt("GameserverPort", 7777);
           
            GAME_SERVER_LOGIN_PORT = serverSettings.getInt("LoginPort", 9014);
            GAME_SERVER_LOGIN_HOST = serverSettings.getString("LoginHost", "127.0.0.1");
           
            REQUEST_ID = serverSettings.getInt("RequestServerID", 0);
            ACCEPT_ALTERNATE_ID = serverSettings.getBoolean("AcceptAlternateID", true);
           
            DATABASE_DRIVER = serverSettings.getString("Driver", "org.mariadb.jdbc.Driver");
            DATABASE_URL = serverSettings.getString("URL", "jdbc:mariadb://localhost/game?useUnicode=true&characterEncoding=utf-8");
            DATABASE_LOGIN = serverSettings.getString("Login", "user");
            DATABASE_PASSWORD = serverSettings.getString("Password", "user");
            DATABASE_MAX_CONNECTIONS = serverSettings.getInt("MaximumDbConnections", 10);
            DATABASE_MAX_IDLE_TIME = serverSettings.getInt("MaximumDbIdleTime", 0);
           
            BACKUP_DATABASE = serverSettings.getBoolean("BackupDatabase", false);
            MYSQL_BIN_PATH = serverSettings.getString("MySqlBinLocation", "");
            BACKUP_PATH = serverSettings.getString("BackupPath", "../backup/");
            BACKUP_DAYS = serverSettings.getInt("BackupDays", 30);
           
            try
            {
                DATAPACK_ROOT = new File(serverSettings.getString("DatapackRoot", ".").replaceAll("\\\\", "/")).getCanonicalFile();
            }
            catch (IOException e)
            {
                LOGGER.log(Level.WARNING, "Error setting datapack root!", e);
                DATAPACK_ROOT = new File(".");
            }
           
            Pattern charNamePattern;
           
            try
            {
                charNamePattern = Pattern.compile(serverSettings.getString("CnameTemplate", ".*"));
            }
            catch (PatternSyntaxException e)
            {
                LOGGER.log(Level.WARNING, "Character name pattern is invalid!", e);
                charNamePattern = Pattern.compile(".*");
            }
           
            CHARNAME_TEMPLATE_PATTERN = charNamePattern;
           
            PET_NAME_TEMPLATE = serverSettings.getString("PetNameTemplate", ".*");
            CLAN_NAME_TEMPLATE = serverSettings.getString("ClanNameTemplate", ".*");
           
            MAX_CHARACTERS_NUMBER_PER_ACCOUNT = serverSettings.getInt("CharMaxNumber", 7);
            MAXIMUM_ONLINE_USERS = serverSettings.getInt("MaximumOnlineUsers", 2000);
           
            final String[] protocols = serverSettings.getString("AllowedProtocolRevisions", "267;268;271;273").split(";");
            PROTOCOL_LIST = new ArrayList<>(protocols.length);
            for (String protocol : protocols)
            {
                try
                {
                    PROTOCOL_LIST.add(Integer.parseInt(protocol.trim()));
                }
                catch (NumberFormatException e)
                {
                    LOGGER.log(Level.WARNING, "Wrong config protocol version: " + protocol + ". Skipped.");
                }
            }
            SERVER_LIST_TYPE = getServerTypeId(serverSettings.getString("ServerListType", "free").split(","));
            SERVER_LIST_AGE = serverSettings.getInt("ServerListAge", 0);
            SERVER_LIST_BRACKET = serverSettings.getBoolean("ServerListBrackets", false);
           
            SCHEDULED_THREAD_POOL_COUNT = serverSettings.getInt("ScheduledThreadPoolCount", -1);
            THREADS_PER_SCHEDULED_THREAD_POOL = serverSettings.getInt("ThreadsPerScheduledThreadPool", 4);
            INSTANT_THREAD_POOL_COUNT = serverSettings.getInt("InstantThreadPoolCount", -1);
            THREADS_PER_INSTANT_THREAD_POOL = serverSettings.getInt("ThreadsPerInstantThreadPool", 2);
            IO_PACKET_THREAD_CORE_SIZE = serverSettings.getInt("UrgentPacketThreadCoreSize", 2);
           
            DEADLOCK_DETECTOR = serverSettings.getBoolean("DeadLockDetector", true);
            DEADLOCK_CHECK_INTERVAL = serverSettings.getInt("DeadLockCheckInterval", 20);
            RESTART_ON_DEADLOCK = serverSettings.getBoolean("RestartOnDeadlock", false);
           
            SERVER_RESTART_SCHEDULE_ENABLED = serverSettings.getBoolean("ServerRestartScheduleEnabled", false);
            SERVER_RESTART_SCHEDULE_MESSAGE = serverSettings.getBoolean("ServerRestartScheduleMessage", false);
            SERVER_RESTART_SCHEDULE_COUNTDOWN = serverSettings.getInt("ServerRestartScheduleCountdown", 600);
            SERVER_RESTART_SCHEDULE = serverSettings.getString("ServerRestartSchedule", "08:00").split(",");
           
            // Hosts and Subnets
            final IPConfigData ipcd = new IPConfigData();
            GAME_SERVER_SUBNETS = ipcd.getSubnets();
            GAME_SERVER_HOSTS = ipcd.getHosts();
           
            // Load Feature config file (if exists)
            final PropertiesParser Feature = new PropertiesParser(FEATURE_CONFIG_FILE);
           
            CH_TELE_FEE_RATIO = Feature.getLong("ClanHallTeleportFunctionFeeRatio", 604800000);
            CH_TELE1_FEE = Feature.getInt("ClanHallTeleportFunctionFeeLvl1", 7000);
            CH_TELE2_FEE = Feature.getInt("ClanHallTeleportFunctionFeeLvl2", 14000);
            CH_SUPPORT_FEE_RATIO = Feature.getLong("ClanHallSupportFunctionFeeRatio", 86400000);
            CH_SUPPORT1_FEE = Feature.getInt("ClanHallSupportFeeLvl1", 2500);
            CH_SUPPORT2_FEE = Feature.getInt("ClanHallSupportFeeLvl2", 5000);
            CH_SUPPORT3_FEE = Feature.getInt("ClanHallSupportFeeLvl3", 7000);
            CH_SUPPORT4_FEE = Feature.getInt("ClanHallSupportFeeLvl4", 11000);
            CH_SUPPORT5_FEE = Feature.getInt("ClanHallSupportFeeLvl5", 21000);
            CH_SUPPORT6_FEE = Feature.getInt("ClanHallSupportFeeLvl6", 36000);
            CH_SUPPORT7_FEE = Feature.getInt("ClanHallSupportFeeLvl7", 37000);
            CH_SUPPORT8_FEE = Feature.getInt("ClanHallSupportFeeLvl8", 52000);
            CH_MPREG_FEE_RATIO = Feature.getLong("ClanHallMpRegenerationFunctionFeeRatio", 86400000);
            CH_MPREG1_FEE = Feature.getInt("ClanHallMpRegenerationFeeLvl1", 2000);
            CH_MPREG2_FEE = Feature.getInt("ClanHallMpRegenerationFeeLvl2", 3750);
            CH_MPREG3_FEE = Feature.getInt("ClanHallMpRegenerationFeeLvl3", 6500);
            CH_MPREG4_FEE = Feature.getInt("ClanHallMpRegenerationFeeLvl4", 13750);
            CH_MPREG5_FEE = Feature.getInt("ClanHallMpRegenerationFeeLvl5", 20000);
            CH_HPREG_FEE_RATIO = Feature.getLong("ClanHallHpRegenerationFunctionFeeRatio", 86400000);
            CH_HPREG1_FEE = Feature.getInt("ClanHallHpRegenerationFeeLvl1", 700);
            CH_HPREG2_FEE = Feature.getInt("ClanHallHpRegenerationFeeLvl2", 800);
            CH_HPREG3_FEE = Feature.getInt("ClanHallHpRegenerationFeeLvl3", 1000);
            CH_HPREG4_FEE = Feature.getInt("ClanHallHpRegenerationFeeLvl4", 1166);
            CH_HPREG5_FEE = Feature.getInt("ClanHallHpRegenerationFeeLvl5", 1500);
            CH_HPREG6_FEE = Feature.getInt("ClanHallHpRegenerationFeeLvl6", 1750);
            CH_HPREG7_FEE = Feature.getInt("ClanHallHpRegenerationFeeLvl7", 2000);
            CH_HPREG8_FEE = Feature.getInt("ClanHallHpRegenerationFeeLvl8", 2250);
            CH_HPREG9_FEE = Feature.getInt("ClanHallHpRegenerationFeeLvl9", 2500);
            CH_HPREG10_FEE = Feature.getInt("ClanHallHpRegenerationFeeLvl10", 3250);
            CH_HPREG11_FEE = Feature.getInt("ClanHallHpRegenerationFeeLvl11", 3270);
            CH_HPREG12_FEE = Feature.getInt("ClanHallHpRegenerationFeeLvl12", 4250);
            CH_HPREG13_FEE = Feature.getInt("ClanHallHpRegenerationFeeLvl13", 5166);
            CH_EXPREG_FEE_RATIO = Feature.getLong("ClanHallExpRegenerationFunctionFeeRatio", 86400000);
            CH_EXPREG1_FEE = Feature.getInt("ClanHallExpRegenerationFeeLvl1", 3000);
            CH_EXPREG2_FEE = Feature.getInt("ClanHallExpRegenerationFeeLvl2", 6000);
            CH_EXPREG3_FEE = Feature.getInt("ClanHallExpRegenerationFeeLvl3", 9000);
            CH_EXPREG4_FEE = Feature.getInt("ClanHallExpRegenerationFeeLvl4", 15000);
            CH_EXPREG5_FEE = Feature.getInt("ClanHallExpRegenerationFeeLvl5", 21000);
            CH_EXPREG6_FEE = Feature.getInt("ClanHallExpRegenerationFeeLvl6", 23330);
            CH_EXPREG7_FEE = Feature.getInt("ClanHallExpRegenerationFeeLvl7", 30000);
            CH_ITEM_FEE_RATIO = Feature.getLong("ClanHallItemCreationFunctionFeeRatio", 86400000);
            CH_ITEM1_FEE = Feature.getInt("ClanHallItemCreationFunctionFeeLvl1", 30000);
            CH_ITEM2_FEE = Feature.getInt("ClanHallItemCreationFunctionFeeLvl2", 70000);
            CH_ITEM3_FEE = Feature.getInt("ClanHallItemCreationFunctionFeeLvl3", 140000);
            CH_CURTAIN_FEE_RATIO = Feature.getLong("ClanHallCurtainFunctionFeeRatio", 604800000);
            CH_CURTAIN1_FEE = Feature.getInt("ClanHallCurtainFunctionFeeLvl1", 2000);
            CH_CURTAIN2_FEE = Feature.getInt("ClanHallCurtainFunctionFeeLvl2", 2500);
            CH_FRONT_FEE_RATIO = Feature.getLong("ClanHallFrontPlatformFunctionFeeRatio", 259200000);
            CH_FRONT1_FEE = Feature.getInt("ClanHallFrontPlatformFunctionFeeLvl1", 1300);
            CH_FRONT2_FEE = Feature.getInt("ClanHallFrontPlatformFunctionFeeLvl2", 4000);
            CH_BUFF_FREE = Feature.getBoolean("AltClanHallMpBuffFree", false);
            SIEGE_HOUR_LIST = new ArrayList<>();
            for (String hour : Feature.getString("SiegeHourList", "").split(","))
            {
                if (Util.isDigit(hour))
                {
                    SIEGE_HOUR_LIST.add(Integer.parseInt(hour));
                }
            }
            CS_TELE_FEE_RATIO = Feature.getLong("CastleTeleportFunctionFeeRatio", 604800000);
            CS_TELE1_FEE = Feature.getInt("CastleTeleportFunctionFeeLvl1", 1000);
            CS_TELE2_FEE = Feature.getInt("CastleTeleportFunctionFeeLvl2", 10000);
            CS_SUPPORT_FEE_RATIO = Feature.getLong("CastleSupportFunctionFeeRatio", 604800000);
            CS_SUPPORT1_FEE = Feature.getInt("CastleSupportFeeLvl1", 49000);
            CS_SUPPORT2_FEE = Feature.getInt("CastleSupportFeeLvl2", 120000);
            CS_MPREG_FEE_RATIO = Feature.getLong("CastleMpRegenerationFunctionFeeRatio", 604800000);
            CS_MPREG1_FEE = Feature.getInt("CastleMpRegenerationFeeLvl1", 45000);
            CS_MPREG2_FEE = Feature.getInt("CastleMpRegenerationFeeLvl2", 65000);
            CS_HPREG_FEE_RATIO = Feature.getLong("CastleHpRegenerationFunctionFeeRatio", 604800000);
            CS_HPREG1_FEE = Feature.getInt("CastleHpRegenerationFeeLvl1", 12000);
            CS_HPREG2_FEE = Feature.getInt("CastleHpRegenerationFeeLvl2", 20000);
            CS_EXPREG_FEE_RATIO = Feature.getLong("CastleExpRegenerationFunctionFeeRatio", 604800000);
            CS_EXPREG1_FEE = Feature.getInt("CastleExpRegenerationFeeLvl1", 63000);
            CS_EXPREG2_FEE = Feature.getInt("CastleExpRegenerationFeeLvl2", 70000);
           
            OUTER_DOOR_UPGRADE_PRICE2 = Feature.getInt("OuterDoorUpgradePriceLvl2", 3000000);
            OUTER_DOOR_UPGRADE_PRICE3 = Feature.getInt("OuterDoorUpgradePriceLvl3", 4000000);
            OUTER_DOOR_UPGRADE_PRICE5 = Feature.getInt("OuterDoorUpgradePriceLvl5", 5000000);
            INNER_DOOR_UPGRADE_PRICE2 = Feature.getInt("InnerDoorUpgradePriceLvl2", 750000);
            INNER_DOOR_UPGRADE_PRICE3 = Feature.getInt("InnerDoorUpgradePriceLvl3", 900000);
            INNER_DOOR_UPGRADE_PRICE5 = Feature.getInt("InnerDoorUpgradePriceLvl5", 1000000);
            WALL_UPGRADE_PRICE2 = Feature.getInt("WallUpgradePriceLvl2", 1600000);
            WALL_UPGRADE_PRICE3 = Feature.getInt("WallUpgradePriceLvl3", 1800000);
            WALL_UPGRADE_PRICE5 = Feature.getInt("WallUpgradePriceLvl5", 2000000);
            TRAP_UPGRADE_PRICE1 = Feature.getInt("TrapUpgradePriceLvl1", 3000000);
            TRAP_UPGRADE_PRICE2 = Feature.getInt("TrapUpgradePriceLvl2", 4000000);
            TRAP_UPGRADE_PRICE3 = Feature.getInt("TrapUpgradePriceLvl3", 5000000);
            TRAP_UPGRADE_PRICE4 = Feature.getInt("TrapUpgradePriceLvl4", 6000000);
           
            FS_TELE_FEE_RATIO = Feature.getLong("FortressTeleportFunctionFeeRatio", 604800000);
            FS_TELE1_FEE = Feature.getInt("FortressTeleportFunctionFeeLvl1", 1000);
            FS_TELE2_FEE = Feature.getInt("FortressTeleportFunctionFeeLvl2", 10000);
            FS_SUPPORT_FEE_RATIO = Feature.getLong("FortressSupportFunctionFeeRatio", 86400000);
            FS_SUPPORT1_FEE = Feature.getInt("FortressSupportFeeLvl1", 7000);
            FS_SUPPORT2_FEE = Feature.getInt("FortressSupportFeeLvl2", 17000);
            FS_MPREG_FEE_RATIO = Feature.getLong("FortressMpRegenerationFunctionFeeRatio", 86400000);
            FS_MPREG1_FEE = Feature.getInt("FortressMpRegenerationFeeLvl1", 6500);
            FS_MPREG2_FEE = Feature.getInt("FortressMpRegenerationFeeLvl2", 9300);
            FS_HPREG_FEE_RATIO = Feature.getLong("FortressHpRegenerationFunctionFeeRatio", 86400000);
            FS_HPREG1_FEE = Feature.getInt("FortressHpRegenerationFeeLvl1", 2000);
            FS_HPREG2_FEE = Feature.getInt("FortressHpRegenerationFeeLvl2", 3500);
            FS_EXPREG_FEE_RATIO = Feature.getLong("FortressExpRegenerationFunctionFeeRatio", 86400000);
            FS_EXPREG1_FEE = Feature.getInt("FortressExpRegenerationFeeLvl1", 9000);
            FS_EXPREG2_FEE = Feature.getInt("FortressExpRegenerationFeeLvl2", 10000);
            FS_UPDATE_FRQ = Feature.getInt("FortressPeriodicUpdateFrequency", 360);
            FS_BLOOD_OATH_COUNT = Feature.getInt("FortressBloodOathCount", 1);
            FS_MAX_SUPPLY_LEVEL = Feature.getInt("FortressMaxSupplyLevel", 6);
            FS_FEE_FOR_CASTLE = Feature.getInt("FortressFeeForCastle", 25000);
            FS_MAX_OWN_TIME = Feature.getInt("FortressMaximumOwnTime", 168);
           
            ALT_GAME_CASTLE_DAWN = Feature.getBoolean("AltCastleForDawn", true);
            ALT_GAME_CASTLE_DUSK = Feature.getBoolean("AltCastleForDusk", true);
            ALT_GAME_REQUIRE_CLAN_CASTLE = Feature.getBoolean("AltRequireClanCastle", false);
            ALT_FESTIVAL_MIN_PLAYER = Feature.getInt("AltFestivalMinPlayer", 5);
            ALT_MAXIMUM_PLAYER_CONTRIB = Feature.getInt("AltMaxPlayerContrib", 1000000);
            ALT_FESTIVAL_MANAGER_START = Feature.getLong("AltFestivalManagerStart", 120000);
            ALT_FESTIVAL_LENGTH = Feature.getLong("AltFestivalLength", 1080000);
            ALT_FESTIVAL_CYCLE_LENGTH = Feature.getLong("AltFestivalCycleLength", 2280000);
            ALT_FESTIVAL_FIRST_SPAWN = Feature.getLong("AltFestivalFirstSpawn", 120000);
            ALT_FESTIVAL_FIRST_SWARM = Feature.getLong("AltFestivalFirstSwarm", 300000);
            ALT_FESTIVAL_SECOND_SPAWN = Feature.getLong("AltFestivalSecondSpawn", 540000);
            ALT_FESTIVAL_SECOND_SWARM = Feature.getLong("AltFestivalSecondSwarm", 720000);
            ALT_FESTIVAL_CHEST_SPAWN = Feature.getLong("AltFestivalChestSpawn", 900000);
            ALT_SIEGE_DAWN_GATES_PDEF_MULT = Feature.getDouble("AltDawnGatesPdefMult", 1.1);
            ALT_SIEGE_DUSK_GATES_PDEF_MULT = Feature.getDouble("AltDuskGatesPdefMult", 0.8);
            ALT_SIEGE_DAWN_GATES_MDEF_MULT = Feature.getDouble("AltDawnGatesMdefMult", 1.1);
            ALT_SIEGE_DUSK_GATES_MDEF_MULT = Feature.getDouble("AltDuskGatesMdefMult", 0.8);
            ALT_STRICT_SEVENSIGNS = Feature.getBoolean("StrictSevenSigns", true);
            ALT_SEVENSIGNS_LAZY_UPDATE = Feature.getBoolean("AltSevenSignsLazyUpdate", true);
           
            SSQ_DAWN_TICKET_QUANTITY = Feature.getInt("SevenSignsDawnTicketQuantity", 300);
            SSQ_DAWN_TICKET_PRICE = Feature.getInt("SevenSignsDawnTicketPrice", 1000);
            SSQ_DAWN_TICKET_BUNDLE = Feature.getInt("SevenSignsDawnTicketBundle", 10);
            SSQ_MANORS_AGREEMENT_ID = Feature.getInt("SevenSignsManorsAgreementId", 6388);
            SSQ_JOIN_DAWN_ADENA_FEE = Feature.getInt("SevenSignsJoinDawnFee", 50000);
           
            TAKE_FORT_POINTS = Feature.getInt("TakeFortPoints", 200);
            LOOSE_FORT_POINTS = Feature.getInt("LooseFortPoints", 0);
            TAKE_CASTLE_POINTS = Feature.getInt("TakeCastlePoints", 1500);
            LOOSE_CASTLE_POINTS = Feature.getInt("LooseCastlePoints", 3000);
            CASTLE_DEFENDED_POINTS = Feature.getInt("CastleDefendedPoints", 750);
            FESTIVAL_WIN_POINTS = Feature.getInt("FestivalOfDarknessWin", 200);
            HERO_POINTS = Feature.getInt("HeroPoints", 1000);
            ROYAL_GUARD_COST = Feature.getInt("CreateRoyalGuardCost", 5000);
            KNIGHT_UNIT_COST = Feature.getInt("CreateKnightUnitCost", 10000);
            KNIGHT_REINFORCE_COST = Feature.getInt("ReinforceKnightUnitCost", 5000);
            BALLISTA_POINTS = Feature.getInt("KillBallistaPoints", 30);
            BLOODALLIANCE_POINTS = Feature.getInt("BloodAlliancePoints", 500);
            BLOODOATH_POINTS = Feature.getInt("BloodOathPoints", 200);
            KNIGHTSEPAULETTE_POINTS = Feature.getInt("KnightsEpaulettePoints", 20);
            REPUTATION_SCORE_PER_KILL = Feature.getInt("ReputationScorePerKill", 1);
            JOIN_ACADEMY_MIN_REP_SCORE = Feature.getInt("CompleteAcademyMinPoints", 190);
            JOIN_ACADEMY_MAX_REP_SCORE = Feature.getInt("CompleteAcademyMaxPoints", 650);
            RAID_RANKING_1ST = Feature.getInt("1stRaidRankingPoints", 1250);
            RAID_RANKING_2ND = Feature.getInt("2ndRaidRankingPoints", 900);
            RAID_RANKING_3RD = Feature.getInt("3rdRaidRankingPoints", 700);
            RAID_RANKING_4TH = Feature.getInt("4thRaidRankingPoints", 600);
            RAID_RANKING_5TH = Feature.getInt("5thRaidRankingPoints", 450);
            RAID_RANKING_6TH = Feature.getInt("6thRaidRankingPoints", 350);
            RAID_RANKING_7TH = Feature.getInt("7thRaidRankingPoints", 300);
            RAID_RANKING_8TH = Feature.getInt("8thRaidRankingPoints", 200);
            RAID_RANKING_9TH = Feature.getInt("9thRaidRankingPoints", 150);
            RAID_RANKING_10TH = Feature.getInt("10thRaidRankingPoints", 100);
            RAID_RANKING_UP_TO_50TH = Feature.getInt("UpTo50thRaidRankingPoints", 25);
            RAID_RANKING_UP_TO_100TH = Feature.getInt("UpTo100thRaidRankingPoints", 12);
            CLAN_LEVEL_6_COST = Feature.getInt("ClanLevel6Cost", 5000);
            CLAN_LEVEL_7_COST = Feature.getInt("ClanLevel7Cost", 10000);
            CLAN_LEVEL_8_COST = Feature.getInt("ClanLevel8Cost", 20000);
            CLAN_LEVEL_9_COST = Feature.getInt("ClanLevel9Cost", 40000);
            CLAN_LEVEL_10_COST = Feature.getInt("ClanLevel10Cost", 40000);
            CLAN_LEVEL_11_COST = Feature.getInt("ClanLevel11Cost", 75000);
            CLAN_LEVEL_6_REQUIREMENT = Feature.getInt("ClanLevel6Requirement", 30);
            CLAN_LEVEL_7_REQUIREMENT = Feature.getInt("ClanLevel7Requirement", 50);
            CLAN_LEVEL_8_REQUIREMENT = Feature.getInt("ClanLevel8Requirement", 80);
            CLAN_LEVEL_9_REQUIREMENT = Feature.getInt("ClanLevel9Requirement", 120);
            CLAN_LEVEL_10_REQUIREMENT = Feature.getInt("ClanLevel10Requirement", 140);
            CLAN_LEVEL_11_REQUIREMENT = Feature.getInt("ClanLevel11Requirement", 170);
            ALLOW_WYVERN_ALWAYS = Feature.getBoolean("AllowRideWyvernAlways", false);
            ALLOW_WYVERN_DURING_SIEGE = Feature.getBoolean("AllowRideWyvernDuringSiege", true);
            ALLOW_MOUNTS_DURING_SIEGE = Feature.getBoolean("AllowRideMountsDuringSiege", false);
           
            // Load Character config file (if exists)
            final PropertiesParser Character = new PropertiesParser(CHARACTER_CONFIG_FILE);
           
            PLAYER_DELEVEL = Character.getBoolean("Delevel", true);
            DECREASE_SKILL_LEVEL = Character.getBoolean("DecreaseSkillOnDelevel", true);
            ALT_WEIGHT_LIMIT = Character.getDouble("AltWeightLimit", 1);
            RUN_SPD_BOOST = Character.getInt("RunSpeedBoost", 0);
            DEATH_PENALTY_CHANCE = Character.getInt("DeathPenaltyChance", 20);
            RESPAWN_RESTORE_CP = Character.getDouble("RespawnRestoreCP", 0) / 100;
            RESPAWN_RESTORE_HP = Character.getDouble("RespawnRestoreHP", 65) / 100;
            RESPAWN_RESTORE_MP = Character.getDouble("RespawnRestoreMP", 0) / 100;
            HP_REGEN_MULTIPLIER = Character.getDouble("HpRegenMultiplier", 100) / 100;
            MP_REGEN_MULTIPLIER = Character.getDouble("MpRegenMultiplier", 100) / 100;
            CP_REGEN_MULTIPLIER = Character.getDouble("CpRegenMultiplier", 100) / 100;
            ENABLE_MODIFY_SKILL_DURATION = Character.getBoolean("EnableModifySkillDuration", false);
           
            // Create Map only if enabled
            if (ENABLE_MODIFY_SKILL_DURATION)
            {
                final String[] propertySplit = Character.getString("SkillDurationList", "").split(";");
                SKILL_DURATION_LIST = new HashMap<>(propertySplit.length);
                for (String skill : propertySplit)
                {
                    final String[] skillSplit = skill.split(",");
                    if (skillSplit.length != 2)
                    {
                        LOGGER.warning("[SkillDurationList]: invalid config property -> SkillDurationList \"" + skill + "\"");
                    }
                    else
                    {
                        try
                        {
                            SKILL_DURATION_LIST.put(Integer.parseInt(skillSplit[0]), Integer.parseInt(skillSplit[1]));
                        }
                        catch (NumberFormatException nfe)
                        {
                            if (!skill.isEmpty())
                            {
                                LOGGER.warning("[SkillDurationList]: invalid config property -> SkillList \"" + skillSplit[0] + "\"" + skillSplit[1]);
                            }
                        }
                    }
                }
            }
            ENABLE_MODIFY_SKILL_REUSE = Character.getBoolean("EnableModifySkillReuse", false);
            // Create Map only if enabled
            if (ENABLE_MODIFY_SKILL_REUSE)
            {
                final String[] propertySplit = Character.getString("SkillReuseList", "").split(";");
                SKILL_REUSE_LIST = new HashMap<>(propertySplit.length);
                for (String skill : propertySplit)
                {
                    final String[] skillSplit = skill.split(",");
                    if (skillSplit.length != 2)
                    {
                        LOGGER.warning("[SkillReuseList]: invalid config property -> SkillReuseList \"" + skill + "\"");
                    }
                    else
                    {
                        try
                        {
                            SKILL_REUSE_LIST.put(Integer.parseInt(skillSplit[0]), Integer.parseInt(skillSplit[1]));
                        }
                        catch (NumberFormatException nfe)
                        {
                            if (!skill.isEmpty())
                            {
                                LOGGER.warning("[SkillReuseList]: invalid config property -> SkillList \"" + skillSplit[0] + "\"" + skillSplit[1]);
                            }
                        }
                    }
                }
            }
           
            AUTO_LEARN_SKILLS = Character.getBoolean("AutoLearnSkills", false);
            AUTO_LEARN_FS_SKILLS = Character.getBoolean("AutoLearnForgottenScrollSkills", false);
            AUTO_LOOT_HERBS = Character.getBoolean("AutoLootHerbs", false);
            BUFFS_MAX_AMOUNT = Character.getByte("MaxBuffAmount", (byte) 20);
            TRIGGERED_BUFFS_MAX_AMOUNT = Character.getByte("MaxTriggeredBuffAmount", (byte) 12);
            DANCES_MAX_AMOUNT = Character.getByte("MaxDanceAmount", (byte) 12);
            DANCE_CANCEL_BUFF = Character.getBoolean("DanceCancelBuff", false);
            DANCE_CONSUME_ADDITIONAL_MP = Character.getBoolean("DanceConsumeAdditionalMP", true);
            ALT_STORE_DANCES = Character.getBoolean("AltStoreDances", false);
            AUTO_LEARN_DIVINE_INSPIRATION = Character.getBoolean("AutoLearnDivineInspiration", false);
            ALT_GAME_CANCEL_BOW = Character.getString("AltGameCancelByHit", "Cast").equalsIgnoreCase("bow") || Character.getString("AltGameCancelByHit", "Cast").equalsIgnoreCase("all");
            ALT_GAME_CANCEL_CAST = Character.getString("AltGameCancelByHit", "Cast").equalsIgnoreCase("cast") || Character.getString("AltGameCancelByHit", "Cast").equalsIgnoreCase("all");
            ALT_GAME_MAGICFAILURES = Character.getBoolean("MagicFailures", true);
            PLAYER_FAKEDEATH_UP_PROTECTION = Character.getInt("PlayerFakeDeathUpProtection", 0);
            STORE_SKILL_COOLTIME = Character.getBoolean("StoreSkillCooltime", true);
            SUBCLASS_STORE_SKILL_COOLTIME = Character.getBoolean("SubclassStoreSkillCooltime", false);
            SUMMON_STORE_SKILL_COOLTIME = Character.getBoolean("SummonStoreSkillCooltime", true);
            ALT_GAME_SHIELD_BLOCKS = Character.getBoolean("AltShieldBlocks", false);
            ALT_PERFECT_SHLD_BLOCK = Character.getInt("AltPerfectShieldBlockRate", 10);
            EFFECT_TICK_RATIO = Character.getLong("EffectTickRatio", 666);
            ALLOW_CLASS_MASTERS = Character.getBoolean("AllowClassMasters", false);
            ALLOW_ENTIRE_TREE = Character.getBoolean("AllowEntireTree", false);
            ALTERNATE_CLASS_MASTER = Character.getBoolean("AlternateClassMaster", false);
            if (ALLOW_CLASS_MASTERS || ALTERNATE_CLASS_MASTER)
            {
                CLASS_MASTER_SETTINGS = new ClassMasterSettings(Character.getString("ConfigClassMaster", ""));
            }
            LIFE_CRYSTAL_NEEDED = Character.getBoolean("LifeCrystalNeeded", true);
            ES_SP_BOOK_NEEDED = Character.getBoolean("EnchantSkillSpBookNeeded", true);
            DIVINE_SP_BOOK_NEEDED = Character.getBoolean("DivineInspirationSpBookNeeded", true);
            ALT_GAME_SKILL_LEARN = Character.getBoolean("AltGameSkillLearn", false);
            ALT_GAME_SUBCLASS_WITHOUT_QUESTS = Character.getBoolean("AltSubClassWithoutQuests", false);
            ALT_GAME_SUBCLASS_EVERYWHERE = Character.getBoolean("AltSubclassEverywhere", false);
            RESTORE_SERVITOR_ON_RECONNECT = Character.getBoolean("RestoreServitorOnReconnect", true);
            RESTORE_PET_ON_RECONNECT = Character.getBoolean("RestorePetOnReconnect", true);
            ALLOW_TRANSFORM_WITHOUT_QUEST = Character.getBoolean("AltTransformationWithoutQuest", false);
            FEE_DELETE_TRANSFER_SKILLS = Character.getInt("FeeDeleteTransferSkills", 10000000);
            FEE_DELETE_SUBCLASS_SKILLS = Character.getInt("FeeDeleteSubClassSkills", 10000000);
            ENABLE_VITALITY = Character.getBoolean("EnableVitality", true);
            RECOVER_VITALITY_ON_RECONNECT = Character.getBoolean("RecoverVitalityOnReconnect", true);
            STARTING_VITALITY_POINTS = Character.getInt("StartingVitalityPoints", 20000);
            RAIDBOSS_USE_VITALITY = Character.getBoolean("RaidbossUseVitality", true);
            MAX_BONUS_EXP = Character.getDouble("MaxExpBonus", 3.5);
            MAX_BONUS_SP = Character.getDouble("MaxSpBonus", 3.5);
            MAX_RUN_SPEED = Character.getInt("MaxRunSpeed", 250);
            MAX_PATK = Character.getInt("MaxPAtk", 999999);
            MAX_MATK = Character.getInt("MaxMAtk", 999999);
            MAX_PCRIT_RATE = Character.getInt("MaxPCritRate", 500);
            MAX_MCRIT_RATE = Character.getInt("MaxMCritRate", 200);
            MAX_PATK_SPEED = Character.getInt("MaxPAtkSpeed", 1500);
            MAX_MATK_SPEED = Character.getInt("MaxMAtkSpeed", 1999);
            MAX_EVASION = Character.getInt("MaxEvasion", 250);
            MIN_ABNORMAL_STATE_SUCCESS_RATE = Character.getInt("MinAbnormalStateSuccessRate", 10);
            MAX_ABNORMAL_STATE_SUCCESS_RATE = Character.getInt("MaxAbnormalStateSuccessRate", 90);
            MAX_SP = Character.getLong("MaxSp", 50000000000L) >= 0 ? Character.getLong("MaxSp", 50000000000L) : Long.MAX_VALUE;
            MAX_SUBCLASS = Character.getByte("MaxSubclass", (byte) 3);
            BASE_SUBCLASS_LEVEL = Character.getByte("BaseSubclassLevel", (byte) 40);
            MAX_SUBCLASS_LEVEL = Character.getByte("MaxSubclassLevel", (byte) 80);
            MAX_PVTSTORESELL_SLOTS_DWARF = Character.getInt("MaxPvtStoreSellSlotsDwarf", 4);
            MAX_PVTSTORESELL_SLOTS_OTHER = Character.getInt("MaxPvtStoreSellSlotsOther", 3);
            MAX_PVTSTOREBUY_SLOTS_DWARF = Character.getInt("MaxPvtStoreBuySlotsDwarf", 5);
            MAX_PVTSTOREBUY_SLOTS_OTHER = Character.getInt("MaxPvtStoreBuySlotsOther", 4);
            INVENTORY_MAXIMUM_NO_DWARF = Character.getInt("MaximumSlotsForNoDwarf", 80);
            INVENTORY_MAXIMUM_DWARF = Character.getInt("MaximumSlotsForDwarf", 100);
            INVENTORY_MAXIMUM_GM = Character.getInt("MaximumSlotsForGMPlayer", 250);
            INVENTORY_MAXIMUM_QUEST_ITEMS = Character.getInt("MaximumSlotsForQuestItems", 100);
            MAX_ITEM_IN_PACKET = Math.max(INVENTORY_MAXIMUM_NO_DWARF, Math.max(INVENTORY_MAXIMUM_DWARF, INVENTORY_MAXIMUM_GM));
            WAREHOUSE_SLOTS_DWARF = Character.getInt("MaximumWarehouseSlotsForDwarf", 120);
            WAREHOUSE_SLOTS_NO_DWARF = Character.getInt("MaximumWarehouseSlotsForNoDwarf", 100);
            WAREHOUSE_SLOTS_CLAN = Character.getInt("MaximumWarehouseSlotsForClan", 150);
            ALT_FREIGHT_SLOTS = Character.getInt("MaximumFreightSlots", 200);
            ALT_FREIGHT_PRICE = Character.getInt("FreightPrice", 1000);
            ENCHANT_CHANCE_ELEMENT_STONE = Character.getDouble("EnchantChanceElementStone", 50);
            ENCHANT_CHANCE_ELEMENT_CRYSTAL = Character.getDouble("EnchantChanceElementCrystal", 30);
            ENCHANT_CHANCE_ELEMENT_JEWEL = Character.getDouble("EnchantChanceElementJewel", 20);
            ENCHANT_CHANCE_ELEMENT_ENERGY = Character.getDouble("EnchantChanceElementEnergy", 10);
            final String[] notenchantable = Character.getString("EnchantBlackList", "7816,7817,7818,7819,7820,7821,7822,7823,7824,7825,7826,7827,7828,7829,7830,7831,13293,13294,13296").split(",");
            ENCHANT_BLACKLIST = new int[notenchantable.length];
            for (int i = 0; i < notenchantable.length; i++)
            {
                ENCHANT_BLACKLIST[i] = Integer.parseInt(notenchantable[i]);
            }
            Arrays.sort(ENCHANT_BLACKLIST);
            DISABLE_OVER_ENCHANTING = Character.getBoolean("DisableOverEnchanting", true);
            AUGMENTATION_NG_SKILL_CHANCE = Character.getInt("AugmentationNGSkillChance", 15);
            AUGMENTATION_NG_GLOW_CHANCE = Character.getInt("AugmentationNGGlowChance", 0);
            AUGMENTATION_MID_SKILL_CHANCE = Character.getInt("AugmentationMidSkillChance", 30);
            AUGMENTATION_MID_GLOW_CHANCE = Character.getInt("AugmentationMidGlowChance", 40);
            AUGMENTATION_HIGH_SKILL_CHANCE = Character.getInt("AugmentationHighSkillChance", 45);
            AUGMENTATION_HIGH_GLOW_CHANCE = Character.getInt("AugmentationHighGlowChance", 70);
            AUGMENTATION_TOP_SKILL_CHANCE = Character.getInt("AugmentationTopSkillChance", 60);
            AUGMENTATION_TOP_GLOW_CHANCE = Character.getInt("AugmentationTopGlowChance", 100);
            AUGMENTATION_BASESTAT_CHANCE = Character.getInt("AugmentationBaseStatChance", 1);
            AUGMENTATION_ACC_SKILL_CHANCE = Character.getInt("AugmentationAccSkillChance", 0);
           
            RETAIL_LIKE_AUGMENTATION = Character.getBoolean("RetailLikeAugmentation", true);
            String[] array = Character.getString("RetailLikeAugmentationNoGradeChance", "55,35,7,3").split(",");
            RETAIL_LIKE_AUGMENTATION_NG_CHANCE = new int[array.length];
            for (int i = 0; i < 4; i++)
            {
                RETAIL_LIKE_AUGMENTATION_NG_CHANCE[i] = Integer.parseInt(array[i]);
            }
            array = Character.getString("RetailLikeAugmentationMidGradeChance", "55,35,7,3").split(",");
            RETAIL_LIKE_AUGMENTATION_MID_CHANCE = new int[array.length];
            for (int i = 0; i < 4; i++)
            {
                RETAIL_LIKE_AUGMENTATION_MID_CHANCE[i] = Integer.parseInt(array[i]);
            }
            array = Character.getString("RetailLikeAugmentationHighGradeChance", "55,35,7,3").split(",");
            RETAIL_LIKE_AUGMENTATION_HIGH_CHANCE = new int[array.length];
            for (int i = 0; i < 4; i++)
            {
                RETAIL_LIKE_AUGMENTATION_HIGH_CHANCE[i] = Integer.parseInt(array[i]);
            }
            array = Character.getString("RetailLikeAugmentationTopGradeChance", "55,35,7,3").split(",");
            RETAIL_LIKE_AUGMENTATION_TOP_CHANCE = new int[array.length];
            for (int i = 0; i < 4; i++)
            {
                RETAIL_LIKE_AUGMENTATION_TOP_CHANCE[i] = Integer.parseInt(array[i]);
            }
            RETAIL_LIKE_AUGMENTATION_ACCESSORY = Character.getBoolean("RetailLikeAugmentationAccessory", true);
           
            array = Character.getString("AugmentationBlackList", "6656,6657,6658,6659,6660,6661,6662,8191,10170,10314,13740,13741,13742,13743,13744,13745,13746,13747,13748,14592,14593,14594,14595,14596,14597,14598,14599,14600,14664,14665,14666,14667,14668,14669,14670,14671,14672,14801,14802,14803,14804,14805,14806,14807,14808,14809,15282,15283,15284,15285,15286,15287,15288,15289,15290,15291,15292,15293,15294,15295,15296,15297,15298,15299,16025,16026,21712,22173,22174,22175").split(",");
            AUGMENTATION_BLACKLIST = new int[array.length];
           
            for (int i = 0; i < array.length; i++)
            {
                AUGMENTATION_BLACKLIST[i] = Integer.parseInt(array[i]);
            }
           
            Arrays.sort(AUGMENTATION_BLACKLIST);
            ALT_ALLOW_AUGMENT_PVP_ITEMS = Character.getBoolean("AltAllowAugmentPvPItems", false);
            ALT_GAME_KARMA_PLAYER_CAN_BE_KILLED_IN_PEACEZONE = Character.getBoolean("AltKarmaPlayerCanBeKilledInPeaceZone", false);
            ALT_GAME_KARMA_PLAYER_CAN_SHOP = Character.getBoolean("AltKarmaPlayerCanShop", true);
            ALT_GAME_KARMA_PLAYER_CAN_TELEPORT = Character.getBoolean("AltKarmaPlayerCanTeleport", true);
            ALT_GAME_KARMA_PLAYER_CAN_USE_GK = Character.getBoolean("AltKarmaPlayerCanUseGK", false);
            ALT_GAME_KARMA_PLAYER_CAN_TRADE = Character.getBoolean("AltKarmaPlayerCanTrade", true);
            ALT_GAME_KARMA_PLAYER_CAN_USE_WAREHOUSE = Character.getBoolean("AltKarmaPlayerCanUseWareHouse", true);
            MAX_PERSONAL_FAME_POINTS = Character.getInt("MaxPersonalFamePoints", 100000);
            FORTRESS_ZONE_FAME_TASK_FREQUENCY = Character.getInt("FortressZoneFameTaskFrequency", 300);
            FORTRESS_ZONE_FAME_AQUIRE_POINTS = Character.getInt("FortressZoneFameAquirePoints", 31);
            CASTLE_ZONE_FAME_TASK_FREQUENCY = Character.getInt("CastleZoneFameTaskFrequency", 300);
            CASTLE_ZONE_FAME_AQUIRE_POINTS = Character.getInt("CastleZoneFameAquirePoints", 125);
            FAME_FOR_DEAD_PLAYERS = Character.getBoolean("FameForDeadPlayers", true);
            IS_CRAFTING_ENABLED = Character.getBoolean("CraftingEnabled", true);
            CRAFT_MASTERWORK = Character.getBoolean("CraftMasterwork", true);
            DWARF_RECIPE_LIMIT = Character.getInt("DwarfRecipeLimit", 50);
            COMMON_RECIPE_LIMIT = Character.getInt("CommonRecipeLimit", 50);
            ALT_GAME_CREATION = Character.getBoolean("AltGameCreation", false);
            ALT_GAME_CREATION_SPEED = Character.getDouble("AltGameCreationSpeed", 1);
            ALT_GAME_CREATION_XP_RATE = Character.getDouble("AltGameCreationXpRate", 1);
            ALT_GAME_CREATION_SP_RATE = Character.getDouble("AltGameCreationSpRate", 1);
            ALT_GAME_CREATION_RARE_XPSP_RATE = Character.getDouble("AltGameCreationRareXpSpRate", 2);
            ALT_BLACKSMITH_USE_RECIPES = Character.getBoolean("AltBlacksmithUseRecipes", true);
            ALT_CLAN_LEADER_DATE_CHANGE = Character.getInt("AltClanLeaderDateChange", 3);
            if ((ALT_CLAN_LEADER_DATE_CHANGE < 1) || (ALT_CLAN_LEADER_DATE_CHANGE > 7))
            {
                LOGGER.log(Level.WARNING, "Wrong value specified for AltClanLeaderDateChange: " + ALT_CLAN_LEADER_DATE_CHANGE);
                ALT_CLAN_LEADER_DATE_CHANGE = 3;
            }
            ALT_CLAN_LEADER_HOUR_CHANGE = Character.getString("AltClanLeaderHourChange", "00:00:00");
            ALT_CLAN_LEADER_INSTANT_ACTIVATION = Character.getBoolean("AltClanLeaderInstantActivation", false);
            ALT_CLAN_JOIN_DAYS = Character.getInt("DaysBeforeJoinAClan", 1);
            ALT_CLAN_CREATE_DAYS = Character.getInt("DaysBeforeCreateAClan", 10);
            ALT_CLAN_DISSOLVE_DAYS = Character.getInt("DaysToPassToDissolveAClan", 7);
            ALT_ALLY_JOIN_DAYS_WHEN_LEAVED = Character.getInt("DaysBeforeJoinAllyWhenLeaved", 1);
            ALT_ALLY_JOIN_DAYS_WHEN_DISMISSED = Character.getInt("DaysBeforeJoinAllyWhenDismissed", 1);
            ALT_ACCEPT_CLAN_DAYS_WHEN_DISMISSED = Character.getInt("DaysBeforeAcceptNewClanWhenDismissed", 1);
            ALT_CREATE_ALLY_DAYS_WHEN_DISSOLVED = Character.getInt("DaysBeforeCreateNewAllyWhenDissolved", 1);
            ALT_MAX_NUM_OF_CLANS_IN_ALLY = Character.getInt("AltMaxNumOfClansInAlly", 3);
            ALT_CLAN_MEMBERS_FOR_WAR = Character.getInt("AltClanMembersForWar", 15);
            ALT_MEMBERS_CAN_WITHDRAW_FROM_CLANWH = Character.getBoolean("AltMembersCanWithdrawFromClanWH", false);
            REMOVE_CASTLE_CIRCLETS = Character.getBoolean("RemoveCastleCirclets", true);
            ALT_PARTY_RANGE = Character.getInt("AltPartyRange", 1600);
            ALT_PARTY_RANGE2 = Character.getInt("AltPartyRange2", 1400);
            ALT_LEAVE_PARTY_LEADER = Character.getBoolean("AltLeavePartyLeader", false);
            INITIAL_EQUIPMENT_EVENT = Character.getBoolean("InitialEquipmentEvent", false);
            STARTING_ADENA = Character.getLong("StartingAdena", 0);
            STARTING_LEVEL = Character.getByte("StartingLevel", (byte) 1);
            STARTING_SP = Character.getInt("StartingSP", 0);
            MAX_ADENA = Character.getLong("MaxAdena", 99900000000L);
            if (MAX_ADENA < 0)
            {
                MAX_ADENA = Long.MAX_VALUE;
            }
            AUTO_LOOT = Character.getBoolean("AutoLoot", false);
            AUTO_LOOT_RAIDS = Character.getBoolean("AutoLootRaids", false);
            AUTO_LOOT_SLOT_LIMIT = Character.getBoolean("AutoLootSlotLimit", false);
            LOOT_RAIDS_PRIVILEGE_INTERVAL = Character.getInt("RaidLootRightsInterval", 900) * 1000;
            LOOT_RAIDS_PRIVILEGE_CC_SIZE = Character.getInt("RaidLootRightsCCSize", 45);
            final String[] autoLootItemIds = Character.getString("AutoLootItemIds", "0").split(",");
            AUTO_LOOT_ITEM_IDS = new ArrayList<>(autoLootItemIds.length);
            for (String item : autoLootItemIds)
            {
                Integer itm = 0;
                try
                {
                    itm = Integer.parseInt(item);
                }
                catch (NumberFormatException nfe)
                {
                    LOGGER.warning("Auto loot item ids: Wrong ItemId passed: " + item);
                    LOGGER.warning(nfe.getMessage());
                }
                if (itm != 0)
                {
                    AUTO_LOOT_ITEM_IDS.add(itm);
                }
            }
            ENABLE_KEYBOARD_MOVEMENT = Character.getBoolean("KeyboardMovement", true);
            UNSTUCK_INTERVAL = Character.getInt("UnstuckInterval", 300);
            TELEPORT_WATCHDOG_TIMEOUT = Character.getInt("TeleportWatchdogTimeout", 0);
            PLAYER_SPAWN_PROTECTION = Character.getInt("PlayerSpawnProtection", 0);
            PLAYER_TELEPORT_PROTECTION = Character.getInt("PlayerTeleportProtection", 0);
            RANDOM_RESPAWN_IN_TOWN_ENABLED = Character.getBoolean("RandomRespawnInTownEnabled", true);
            OFFSET_ON_TELEPORT_ENABLED = Character.getBoolean("OffsetOnTeleportEnabled", true);
            MAX_OFFSET_ON_TELEPORT = Character.getInt("MaxOffsetOnTeleport", 50);
            PETITIONING_ALLOWED = Character.getBoolean("PetitioningAllowed", true);
            MAX_PETITIONS_PER_PLAYER = Character.getInt("MaxPetitionsPerPlayer", 5);
            MAX_PETITIONS_PENDING = Character.getInt("MaxPetitionsPending", 25);
            FREE_TELEPORTING = Character.getBoolean("FreeTeleporting", false);
            DELETE_DAYS = Character.getInt("DeleteCharAfterDays", 7);
            PARTY_XP_CUTOFF_METHOD = Character.getString("PartyXpCutoffMethod", "highfive");
            PARTY_XP_CUTOFF_PERCENT = Character.getDouble("PartyXpCutoffPercent", 3);
            PARTY_XP_CUTOFF_LEVEL = Character.getInt("PartyXpCutoffLevel", 20);
            final String[] gaps = Character.getString("PartyXpCutoffGaps", "0,9;10,14;15,99").split(";");
            PARTY_XP_CUTOFF_GAPS = new int[gaps.length][2];
            for (int i = 0; i < gaps.length; i++)
            {
                PARTY_XP_CUTOFF_GAPS[i] = new int[]
                {
                    Integer.parseInt(gaps[i].split(",")[0]),
                    Integer.parseInt(gaps[i].split(",")[1])
                };
            }
            final String[] percents = Character.getString("PartyXpCutoffGapPercent", "100;30;0").split(";");
            PARTY_XP_CUTOFF_GAP_PERCENTS = new int[percents.length];
            for (int i = 0; i < percents.length; i++)
            {
                PARTY_XP_CUTOFF_GAP_PERCENTS[i] = Integer.parseInt(percents[i]);
            }
            DISABLE_TUTORIAL = Character.getBoolean("DisableTutorial", false);
            EXPERTISE_PENALTY = Character.getBoolean("ExpertisePenalty", true);
            STORE_RECIPE_SHOPLIST = Character.getBoolean("StoreRecipeShopList", false);
            STORE_UI_SETTINGS = Character.getBoolean("StoreCharUiSettings", false);
            FORBIDDEN_NAMES = Character.getString("ForbiddenNames", "").split(",");
            SILENCE_MODE_EXCLUDE = Character.getBoolean("SilenceModeExclude", false);
            ALT_VALIDATE_TRIGGER_SKILLS = Character.getBoolean("AltValidateTriggerSkills", false);
            PLAYER_MOVEMENT_BLOCK_TIME = Character.getInt("NpcTalkBlockingTime", 0) * 1000;
           
            NEVIT_ENABLED = Character.getBoolean("NevitEnabled", true);
            NEVIT_MAX_POINTS = Character.getInt("NevitMaxPoints", 7200);
            NEVIT_BONUS_EFFECT_TIME = Character.getInt("NevitBonusEffectTime", 180);
            NEVIT_ADVENT_TIME = Character.getInt("NevitAdventTime", 14400);
            NEVIT_IGNORE_ADVENT_TIME = Character.getBoolean("NevitIgnoreAdventTime", false);
           
            // Load Telnet config file (if exists)
            final PropertiesParser telnetSettings = new PropertiesParser(TELNET_CONFIG_FILE);
           
            TELNET_ENABLED = telnetSettings.getBoolean("EnableTelnet", false);
            TELNET_PORT = telnetSettings.getInt("Port", 12345);
            TELNET_HOSTNAME = telnetSettings.getString("BindAddress", "127.0.0.1");
            TELNET_PASSWORD = telnetSettings.getString("Password", "");
            TELNET_HOSTS = Arrays.asList(telnetSettings.getString("ListOfHosts", "127.0.0.1,::1").split(","));
           
            // Load IdFactory config file (if exists)
            final PropertiesParser IdFactory = new PropertiesParser(IDFACTORY_CONFIG_FILE);
           
            IDFACTORY_TYPE = IdFactory.getEnum("IDFactory", IdFactoryType.class, IdFactoryType.BitSet);
            BAD_ID_CHECKING = IdFactory.getBoolean("BadIdChecking", true);
           
            // Load General config file (if exists)
            final PropertiesParser General = new PropertiesParser(GENERAL_CONFIG_FILE);
            EVERYBODY_HAS_ADMIN_RIGHTS = General.getBoolean("EverybodyHasAdminRights", false);
            SERVER_GMONLY = General.getBoolean("ServerGMOnly", false);
            GM_HERO_AURA = General.getBoolean("GMHeroAura", false);
            GM_STARTUP_BUILDER_HIDE = General.getBoolean("GMStartupBuilderHide", false);
            GM_STARTUP_INVULNERABLE = General.getBoolean("GMStartupInvulnerable", false);
            GM_STARTUP_INVISIBLE = General.getBoolean("GMStartupInvisible", false);
            GM_STARTUP_SILENCE = General.getBoolean("GMStartupSilence", false);
            GM_STARTUP_AUTO_LIST = General.getBoolean("GMStartupAutoList", false);
            GM_STARTUP_DIET_MODE = General.getBoolean("GMStartupDietMode", false);
            GM_ITEM_RESTRICTION = General.getBoolean("GMItemRestriction", true);
            GM_SKILL_RESTRICTION = General.getBoolean("GMSkillRestriction", true);
            GM_TRADE_RESTRICTED_ITEMS = General.getBoolean("GMTradeRestrictedItems", false);
            GM_RESTART_FIGHTING = General.getBoolean("GMRestartFighting", true);
            GM_ANNOUNCER_NAME = General.getBoolean("GMShowAnnouncerName", false);
            GM_CRITANNOUNCER_NAME = General.getBoolean("GMShowCritAnnouncerName", false);
            GM_GIVE_SPECIAL_SKILLS = General.getBoolean("GMGiveSpecialSkills", false);
            GM_GIVE_SPECIAL_AURA_SKILLS = General.getBoolean("GMGiveSpecialAuraSkills", false);
            GM_DEBUG_HTML_PATHS = General.getBoolean("GMDebugHtmlPaths", true);
            USE_SUPER_HASTE_AS_GM_SPEED = General.getBoolean("UseSuperHasteAsGMSpeed", false);
            LOG_CHAT = General.getBoolean("LogChat", false);
            LOG_AUTO_ANNOUNCEMENTS = General.getBoolean("LogAutoAnnouncements", false);
            LOG_ITEMS = General.getBoolean("LogItems", false);
            LOG_ITEMS_SMALL_LOG = General.getBoolean("LogItemsSmallLog", false);
            LOG_ITEM_ENCHANTS = General.getBoolean("LogItemEnchants", false);
            LOG_SKILL_ENCHANTS = General.getBoolean("LogSkillEnchants", false);
            GMAUDIT = General.getBoolean("GMAudit", false);
            SKILL_CHECK_ENABLE = General.getBoolean("SkillCheckEnable", false);
            SKILL_CHECK_REMOVE = General.getBoolean("SkillCheckRemove", false);
            SKILL_CHECK_GM = General.getBoolean("SkillCheckGM", true);
            HTML_ACTION_CACHE_DEBUG = General.getBoolean("HtmlActionCacheDebug", false);
            PACKET_HANDLER_DEBUG = General.getBoolean("PacketHandlerDebug", false);
            DEVELOPER = General.getBoolean("Developer", false);
            ALT_DEV_NO_HANDLERS = General.getBoolean("AltDevNoHandlers", false) || Boolean.getBoolean("nohandlers");
            ALT_DEV_NO_QUESTS = General.getBoolean("AltDevNoQuests", false) || Boolean.getBoolean("noquests");
            ALT_DEV_NO_SPAWNS = General.getBoolean("AltDevNoSpawns", false) || Boolean.getBoolean("nospawns");
            ALT_DEV_SHOW_QUESTS_LOAD_IN_LOGS = General.getBoolean("AltDevShowQuestsLoadInLogs", false);
            ALT_DEV_SHOW_SCRIPTS_LOAD_IN_LOGS = General.getBoolean("AltDevShowScriptsLoadInLogs", false);
            ALLOW_DISCARDITEM = General.getBoolean("AllowDiscardItem", true);
            AUTODESTROY_ITEM_AFTER = General.getInt("AutoDestroyDroppedItemAfter", 600);
            HERB_AUTO_DESTROY_TIME = General.getInt("AutoDestroyHerbTime", 60) * 1000;
            final String[] split = General.getString("ListOfProtectedItems", "0").split(",");
            LIST_PROTECTED_ITEMS = new ArrayList<>(split.length);
            for (String id : split)
            {
                LIST_PROTECTED_ITEMS.add(Integer.parseInt(id));
            }
            DATABASE_CLEAN_UP = General.getBoolean("DatabaseCleanUp", true);
            CHAR_DATA_STORE_INTERVAL = General.getInt("CharacterDataStoreInterval", 15) * 60 * 1000;
            LAZY_ITEMS_UPDATE = General.getBoolean("LazyItemsUpdate", false);
            UPDATE_ITEMS_ON_CHAR_STORE = General.getBoolean("UpdateItemsOnCharStore", false);
            DESTROY_DROPPED_PLAYER_ITEM = General.getBoolean("DestroyPlayerDroppedItem", false);
            DESTROY_EQUIPABLE_PLAYER_ITEM = General.getBoolean("DestroyEquipableItem", false);
            DESTROY_ALL_ITEMS = General.getBoolean("DestroyAllItems", false);
            SAVE_DROPPED_ITEM = General.getBoolean("SaveDroppedItem", false);
            EMPTY_DROPPED_ITEM_TABLE_AFTER_LOAD = General.getBoolean("EmptyDroppedItemTableAfterLoad", false);
            SAVE_DROPPED_ITEM_INTERVAL = General.getInt("SaveDroppedItemInterval", 60) * 60000;
            CLEAR_DROPPED_ITEM_TABLE = General.getBoolean("ClearDroppedItemTable", false);
            AUTODELETE_INVALID_QUEST_DATA = General.getBoolean("AutoDeleteInvalidQuestData", false);
            MULTIPLE_ITEM_DROP = General.getBoolean("MultipleItemDrop", true);
            FORCE_INVENTORY_UPDATE = General.getBoolean("ForceInventoryUpdate", false);
            LAZY_CACHE = General.getBoolean("LazyCache", true);
            CACHE_CHAR_NAMES = General.getBoolean("CacheCharNames", true);
            MIN_NPC_ANIMATION = General.getInt("MinNPCAnimation", 10);
            MAX_NPC_ANIMATION = General.getInt("MaxNPCAnimation", 20);
            MIN_MONSTER_ANIMATION = General.getInt("MinMonsterAnimation", 5);
            MAX_MONSTER_ANIMATION = General.getInt("MaxMonsterAnimation", 20);
            GRIDS_ALWAYS_ON = General.getBoolean("GridsAlwaysOn", false);
            GRID_NEIGHBOR_TURNON_TIME = General.getInt("GridNeighborTurnOnTime", 1);
            GRID_NEIGHBOR_TURNOFF_TIME = General.getInt("GridNeighborTurnOffTime", 90);
            PEACE_ZONE_MODE = General.getInt("PeaceZoneMode", 0);
            DEFAULT_GLOBAL_CHAT = General.getString("GlobalChat", "ON");
            DEFAULT_TRADE_CHAT = General.getString("TradeChat", "ON");
            MINIMUM_CHAT_LEVEL = General.getInt("MinimumChatLevel", 0);
            ALLOW_WAREHOUSE = General.getBoolean("AllowWarehouse", true);
            WAREHOUSE_CACHE = General.getBoolean("WarehouseCache", false);
            WAREHOUSE_CACHE_TIME = General.getInt("WarehouseCacheTime", 15);
            ALLOW_REFUND = General.getBoolean("AllowRefund", true);
            ALLOW_MAIL = General.getBoolean("AllowMail", true);
            ALLOW_ATTACHMENTS = General.getBoolean("AllowAttachments", true);
            ALLOW_WEAR = General.getBoolean("AllowWear", true);
            WEAR_DELAY = General.getInt("WearDelay", 5);
            WEAR_PRICE = General.getInt("WearPrice", 10);
            INSTANCE_FINISH_TIME = 1000 * General.getInt("DefaultFinishTime", 300);
            RESTORE_PLAYER_INSTANCE = General.getBoolean("RestorePlayerInstance", false);
            ALLOW_SUMMON_IN_INSTANCE = General.getBoolean("AllowSummonInInstance", false);
            EJECT_DEAD_PLAYER_TIME = 1000 * General.getInt("EjectDeadPlayerTime", 60);
            ALLOW_LOTTERY = General.getBoolean("AllowLottery", true);
            ALLOW_RACE = General.getBoolean("AllowRace", true);
            ALLOW_WATER = General.getBoolean("AllowWater", true);
            ALLOW_RENTPET = General.getBoolean("AllowRentPet", false);
            ALLOW_FISHING = General.getBoolean("AllowFishing", true);
            ALLOW_MANOR = General.getBoolean("AllowManor", true);
            ALLOW_BOAT = General.getBoolean("AllowBoat", true);
            BOAT_BROADCAST_RADIUS = General.getInt("BoatBroadcastRadius", 20000);
            ALLOW_CURSED_WEAPONS = General.getBoolean("AllowCursedWeapons", true);
            SERVER_NEWS = General.getBoolean("ShowServerNews", false);
            ENABLE_COMMUNITY_BOARD = General.getBoolean("EnableCommunityBoard", true);
            BBS_DEFAULT = General.getString("BBSDefault", "_bbshome");
            USE_SAY_FILTER = General.getBoolean("UseChatFilter", false);
            CHAT_FILTER_CHARS = General.getString("ChatFilterChars", "^_^");
            final String[] propertySplit4 = General.getString("BanChatChannels", "GENERAL;SHOUT;WORLD;TRADE;HERO_VOICE").trim().split(";");
            BAN_CHAT_CHANNELS = new HashSet<>();
            try
            {
                for (String chatId : propertySplit4)
                {
                    BAN_CHAT_CHANNELS.add(Enum.valueOf(ChatType.class, chatId));
                }
            }
            catch (NumberFormatException nfe)
            {
                LOGGER.log(Level.WARNING, nfe.getMessage(), nfe);
            }
            ALT_MANOR_REFRESH_TIME = General.getInt("AltManorRefreshTime", 20);
            ALT_MANOR_REFRESH_MIN = General.getInt("AltManorRefreshMin", 0);
            ALT_MANOR_APPROVE_TIME = General.getInt("AltManorApproveTime", 4);
            ALT_MANOR_APPROVE_MIN = General.getInt("AltManorApproveMin", 30);
            ALT_MANOR_MAINTENANCE_MIN = General.getInt("AltManorMaintenanceMin", 6);
            ALT_MANOR_SAVE_ALL_ACTIONS = General.getBoolean("AltManorSaveAllActions", false);
            ALT_MANOR_SAVE_PERIOD_RATE = General.getInt("AltManorSavePeriodRate", 2);
            ALT_LOTTERY_PRIZE = General.getLong("AltLotteryPrize", 50000);
            ALT_LOTTERY_TICKET_PRICE = General.getLong("AltLotteryTicketPrice", 2000);
            ALT_LOTTERY_5_NUMBER_RATE = General.getFloat("AltLottery5NumberRate", 0.6f);
            ALT_LOTTERY_4_NUMBER_RATE = General.getFloat("AltLottery4NumberRate", 0.2f);
            ALT_LOTTERY_3_NUMBER_RATE = General.getFloat("AltLottery3NumberRate", 0.2f);
            ALT_LOTTERY_2_AND_1_NUMBER_PRIZE = General.getLong("AltLottery2and1NumberPrize", 200);
            ALT_FISH_CHAMPIONSHIP_ENABLED = General.getBoolean("AltFishChampionshipEnabled", true);
            ALT_FISH_CHAMPIONSHIP_REWARD_ITEM = General.getInt("AltFishChampionshipRewardItemId", 57);
            ALT_FISH_CHAMPIONSHIP_REWARD_1 = General.getInt("AltFishChampionshipReward1", 800000);
            ALT_FISH_CHAMPIONSHIP_REWARD_2 = General.getInt("AltFishChampionshipReward2", 500000);
            ALT_FISH_CHAMPIONSHIP_REWARD_3 = General.getInt("AltFishChampionshipReward3", 300000);
            ALT_FISH_CHAMPIONSHIP_REWARD_4 = General.getInt("AltFishChampionshipReward4", 200000);
            ALT_FISH_CHAMPIONSHIP_REWARD_5 = General.getInt("AltFishChampionshipReward5", 100000);
            ALT_ITEM_AUCTION_ENABLED = General.getBoolean("AltItemAuctionEnabled", true);
            ALT_ITEM_AUCTION_EXPIRED_AFTER = General.getInt("AltItemAuctionExpiredAfter", 14);
            ALT_ITEM_AUCTION_TIME_EXTENDS_ON_BID = General.getInt("AltItemAuctionTimeExtendsOnBid", 0) * 1000;
            FS_TIME_ATTACK = General.getInt("TimeOfAttack", 50);
            FS_TIME_COOLDOWN = General.getInt("TimeOfCoolDown", 5);
            FS_TIME_ENTRY = General.getInt("TimeOfEntry", 3);
            FS_TIME_WARMUP = General.getInt("TimeOfWarmUp", 2);
            FS_PARTY_MEMBER_COUNT = General.getInt("NumberOfNecessaryPartyMembers", 4);
            if (FS_TIME_ATTACK <= 0)
            {
                FS_TIME_ATTACK = 50;
            }
            if (FS_TIME_COOLDOWN <= 0)
            {
                FS_TIME_COOLDOWN = 5;
            }
            if (FS_TIME_ENTRY <= 0)
            {
                FS_TIME_ENTRY = 3;
            }
            if (FS_TIME_ENTRY <= 0)
            {
                FS_TIME_ENTRY = 3;
            }
            if (FS_TIME_ENTRY <= 0)
            {
                FS_TIME_ENTRY = 3;
            }
            RIFT_MIN_PARTY_SIZE = General.getInt("RiftMinPartySize", 5);
            RIFT_MAX_JUMPS = General.getInt("MaxRiftJumps", 4);
            RIFT_SPAWN_DELAY = General.getInt("RiftSpawnDelay", 10000);
            RIFT_AUTO_JUMPS_TIME_MIN = General.getInt("AutoJumpsDelayMin", 480);
            RIFT_AUTO_JUMPS_TIME_MAX = General.getInt("AutoJumpsDelayMax", 600);
            RIFT_BOSS_ROOM_TIME_MUTIPLY = General.getFloat("BossRoomTimeMultiply", 1.5f);
            RIFT_ENTER_COST_RECRUIT = General.getInt("RecruitCost", 18);
            RIFT_ENTER_COST_SOLDIER = General.getInt("SoldierCost", 21);
            RIFT_ENTER_COST_OFFICER = General.getInt("OfficerCost", 24);
            RIFT_ENTER_COST_CAPTAIN = General.getInt("CaptainCost", 27);
            RIFT_ENTER_COST_COMMANDER = General.getInt("CommanderCost", 30);
            RIFT_ENTER_COST_HERO = General.getInt("HeroCost", 33);
            DEFAULT_PUNISH = IllegalActionPunishmentType.findByName(General.getString("DefaultPunish", "KICK"));
            DEFAULT_PUNISH_PARAM = General.getInt("DefaultPunishParam", 0);
            ONLY_GM_ITEMS_FREE = General.getBoolean("OnlyGMItemsFree", true);
            JAIL_IS_PVP = General.getBoolean("JailIsPvp", false);
            JAIL_DISABLE_CHAT = General.getBoolean("JailDisableChat", true);
            JAIL_DISABLE_TRANSACTION = General.getBoolean("JailDisableTransaction", false);
            CUSTOM_NPC_DATA = General.getBoolean("CustomNpcData", false);
            CUSTOM_TELEPORT_TABLE = General.getBoolean("CustomTeleportTable", false);
            CUSTOM_SKILLS_LOAD = General.getBoolean("CustomSkillsLoad", false);
            CUSTOM_ITEMS_LOAD = General.getBoolean("CustomItemsLoad", false);
            CUSTOM_MULTISELL_LOAD = General.getBoolean("CustomMultisellLoad", false);
            CUSTOM_BUYLIST_LOAD = General.getBoolean("CustomBuyListLoad", false);
            ALT_BIRTHDAY_GIFT = General.getInt("AltBirthdayGift", 22187);
            ALT_BIRTHDAY_MAIL_SUBJECT = General.getString("AltBirthdayMailSubject", "Happy Birthday!");
            ALT_BIRTHDAY_MAIL_TEXT = General.getString("AltBirthdayMailText", "Hello Adventurer!! Seeing as you're one year older now, I thought I would send you some birthday cheer :) Please find your birthday pack attached. May these gifts bring you joy and happiness on this very special day." + EOL + EOL + "Sincerely, Alegria");
            ENABLE_BLOCK_CHECKER_EVENT = General.getBoolean("EnableBlockCheckerEvent", false);
            MIN_BLOCK_CHECKER_TEAM_MEMBERS = General.getInt("BlockCheckerMinTeamMembers", 2);
            if (MIN_BLOCK_CHECKER_TEAM_MEMBERS < 1)
            {
                MIN_BLOCK_CHECKER_TEAM_MEMBERS = 1;
            }
            else if (MIN_BLOCK_CHECKER_TEAM_MEMBERS > 6)
            {
                MIN_BLOCK_CHECKER_TEAM_MEMBERS = 6;
            }
            HBCE_FAIR_PLAY = General.getBoolean("HBCEFairPlay", false);
            HELLBOUND_WITHOUT_QUEST = General.getBoolean("HellboundWithoutQuest", false);
           
            NORMAL_ENCHANT_COST_MULTIPLIER = General.getInt("NormalEnchantCostMultipiler", 1);
            SAFE_ENCHANT_COST_MULTIPLIER = General.getInt("SafeEnchantCostMultipiler", 5);
           
            BOTREPORT_ENABLE = General.getBoolean("EnableBotReportButton", false);
            BOTREPORT_RESETPOINT_HOUR = General.getString("BotReportPointsResetHour", "00:00").split(":");
            BOTREPORT_REPORT_DELAY = General.getInt("BotReportDelay", 30) * 60000;
            BOTREPORT_ALLOW_REPORTS_FROM_SAME_CLAN_MEMBERS = General.getBoolean("AllowReportsFromSameClanMembers", false);
            ENABLE_PRIME_SHOP = General.getBoolean("EnablePrimeShop", false);
            PRIME_SHOP_ITEM_ID = General.getInt("PrimeShopItemId", -1);
            ENABLE_FALLING_DAMAGE = General.getBoolean("EnableFallingDamage", true);
           
            // Load FloodProtector config file
            final PropertiesParser FloodProtectors = new PropertiesParser(FLOOD_PROTECTOR_CONFIG_FILE);
           
            loadFloodProtectorConfigs(FloodProtectors);
           
            // Load NPC config file (if exists)
            final PropertiesParser NPC = new PropertiesParser(NPC_CONFIG_FILE);
           
            ANNOUNCE_MAMMON_SPAWN = NPC.getBoolean("AnnounceMammonSpawn", false);
            ALT_MOB_AGRO_IN_PEACEZONE = NPC.getBoolean("AltMobAgroInPeaceZone", true);
            ALT_ATTACKABLE_NPCS = NPC.getBoolean("AltAttackableNpcs", true);
            ALT_GAME_VIEWNPC = NPC.getBoolean("AltGameViewNpc", false);
            MAX_AGGRO_RANGE = NPC.getInt("MaxAggroRange", 450);
            MAX_DRIFT_RANGE = NPC.getInt("MaxDriftRange", 300);
            SHOW_NPC_LVL = NPC.getBoolean("ShowNpcLevel", false);
            SHOW_CREST_WITHOUT_QUEST = NPC.getBoolean("ShowCrestWithoutQuest", false);
            ENABLE_RANDOM_ENCHANT_EFFECT = NPC.getBoolean("EnableRandomEnchantEffect", false);
            MIN_NPC_LVL_DMG_PENALTY = NPC.getInt("MinNPCLevelForDmgPenalty", 78);
            NPC_DMG_PENALTY = parseConfigLine(NPC.getString("DmgPenaltyForLvLDifferences", "0.7, 0.6, 0.6, 0.55"));
            NPC_CRIT_DMG_PENALTY = parseConfigLine(NPC.getString("CritDmgPenaltyForLvLDifferences", "0.75, 0.65, 0.6, 0.58"));
            NPC_SKILL_DMG_PENALTY = parseConfigLine(NPC.getString("SkillDmgPenaltyForLvLDifferences", "0.8, 0.7, 0.65, 0.62"));
            MIN_NPC_LVL_MAGIC_PENALTY = NPC.getInt("MinNPCLevelForMagicPenalty", 78);
            NPC_SKILL_CHANCE_PENALTY = parseConfigLine(NPC.getString("SkillChancePenaltyForLvLDifferences", "2.5, 3.0, 3.25, 3.5"));
            DECAY_TIME_TASK = NPC.getInt("DecayTimeTask", 5000);
            DEFAULT_CORPSE_TIME = NPC.getInt("DefaultCorpseTime", 7);
            SPOILED_CORPSE_EXTEND_TIME = NPC.getInt("SpoiledCorpseExtendTime", 10);
            CORPSE_CONSUME_SKILL_ALLOWED_TIME_BEFORE_DECAY = NPC.getInt("CorpseConsumeSkillAllowedTimeBeforeDecay", 2000);
            GUARD_ATTACK_AGGRO_MOB = NPC.getBoolean("GuardAttackAggroMob", false);
            ENABLE_GUARD_RETURN = NPC.getBoolean("EnableGuardReturn", false);
            ALLOW_WYVERN_UPGRADER = NPC.getBoolean("AllowWyvernUpgrader", false);
            final String[] listPetRentNpc = NPC.getString("ListPetRentNpc", "30827").split(",");
            LIST_PET_RENT_NPC = new ArrayList<>(listPetRentNpc.length);
            for (String id : listPetRentNpc)
            {
                LIST_PET_RENT_NPC.add(Integer.valueOf(id));
            }
            RAID_HP_REGEN_MULTIPLIER = NPC.getDouble("RaidHpRegenMultiplier", 100) / 100;
            RAID_MP_REGEN_MULTIPLIER = NPC.getDouble("RaidMpRegenMultiplier", 100) / 100;
            RAID_PDEFENCE_MULTIPLIER = NPC.getDouble("RaidPDefenceMultiplier", 100) / 100;
            RAID_MDEFENCE_MULTIPLIER = NPC.getDouble("RaidMDefenceMultiplier", 100) / 100;
            RAID_PATTACK_MULTIPLIER = NPC.getDouble("RaidPAttackMultiplier", 100) / 100;
            RAID_MATTACK_MULTIPLIER = NPC.getDouble("RaidMAttackMultiplier", 100) / 100;
            RAID_MIN_RESPAWN_MULTIPLIER = NPC.getFloat("RaidMinRespawnMultiplier", 1.0f);
            RAID_MAX_RESPAWN_MULTIPLIER = NPC.getFloat("RaidMaxRespawnMultiplier", 1.0f);
            RAID_MINION_RESPAWN_TIMER = NPC.getInt("RaidMinionRespawnTime", 300000);
            final String[] propertySplit = NPC.getString("CustomMinionsRespawnTime", "").split(";");
            MINIONS_RESPAWN_TIME = new HashMap<>(propertySplit.length);
            for (String prop : propertySplit)
            {
                final String[] propSplit = prop.split(",");
                if (propSplit.length != 2)
                {
                    LOGGER.warning("[CustomMinionsRespawnTime]: invalid config property -> CustomMinionsRespawnTime \"" + prop + "\"");
                }
               
                try
                {
                    MINIONS_RESPAWN_TIME.put(Integer.valueOf(propSplit[0]), Integer.valueOf(propSplit[1]));
                }
                catch (NumberFormatException nfe)
                {
                    if (!prop.isEmpty())
                    {
                        LOGGER.warning("[CustomMinionsRespawnTime]: invalid config property -> CustomMinionsRespawnTime \"" + propSplit[0] + "\"" + propSplit[1]);
                    }
                }
            }
            FORCE_DELETE_MINIONS = NPC.getBoolean("ForceDeleteMinions", false);
           
            RAID_DISABLE_CURSE = NPC.getBoolean("DisableRaidCurse", false);
            RAID_CHAOS_TIME = NPC.getInt("RaidChaosTime", 10);
            GRAND_CHAOS_TIME = NPC.getInt("GrandChaosTime", 10);
            MINION_CHAOS_TIME = NPC.getInt("MinionChaosTime", 10);
            INVENTORY_MAXIMUM_PET = NPC.getInt("MaximumSlotsForPet", 12);
            PET_HP_REGEN_MULTIPLIER = NPC.getDouble("PetHpRegenMultiplier", 100) / 100;
            PET_MP_REGEN_MULTIPLIER = NPC.getDouble("PetMpRegenMultiplier", 100) / 100;
           
            // Load Rates config file (if exists)
            final PropertiesParser RatesSettings = new PropertiesParser(RATES_CONFIG_FILE);
           
            RATE_XP = RatesSettings.getFloat("RateXp", 1);
            RATE_SP = RatesSettings.getFloat("RateSp", 1);
            RATE_PARTY_XP = RatesSettings.getFloat("RatePartyXp", 1);
            RATE_PARTY_SP = RatesSettings.getFloat("RatePartySp", 1);
            RATE_EXTRACTABLE = RatesSettings.getFloat("RateExtractable", 1);
            RATE_DROP_MANOR = RatesSettings.getInt("RateDropManor", 1);
            RATE_QUEST_DROP = RatesSettings.getFloat("RateQuestDrop", 1);
            RATE_QUEST_REWARD = RatesSettings.getFloat("RateQuestReward", 1);
            RATE_QUEST_REWARD_XP = RatesSettings.getFloat("RateQuestRewardXP", 1);
            RATE_QUEST_REWARD_SP = RatesSettings.getFloat("RateQuestRewardSP", 1);
            RATE_QUEST_REWARD_ADENA = RatesSettings.getFloat("RateQuestRewardAdena", 1);
            RATE_QUEST_REWARD_USE_MULTIPLIERS = RatesSettings.getBoolean("UseQuestRewardMultipliers", false);
            RATE_QUEST_REWARD_POTION = RatesSettings.getFloat("RateQuestRewardPotion", 1);
            RATE_QUEST_REWARD_SCROLL = RatesSettings.getFloat("RateQuestRewardScroll", 1);
            RATE_QUEST_REWARD_RECIPE = RatesSettings.getFloat("RateQuestRewardRecipe", 1);
            RATE_QUEST_REWARD_MATERIAL = RatesSettings.getFloat("RateQuestRewardMaterial", 1);
            RATE_HB_TRUST_INCREASE = RatesSettings.getFloat("RateHellboundTrustIncrease", 1);
            RATE_HB_TRUST_DECREASE = RatesSettings.getFloat("RateHellboundTrustDecrease", 1);
           
            RATE_VITALITY_LEVEL_1 = RatesSettings.getFloat("RateVitalityLevel1", 1.5f);
            RATE_VITALITY_LEVEL_2 = RatesSettings.getFloat("RateVitalityLevel2", 2);
            RATE_VITALITY_LEVEL_3 = RatesSettings.getFloat("RateVitalityLevel3", 2.5f);
            RATE_VITALITY_LEVEL_4 = RatesSettings.getFloat("RateVitalityLevel4", 3);
            RATE_RECOVERY_VITALITY_PEACE_ZONE = RatesSettings.getFloat("RateRecoveryPeaceZone", 1);
            RATE_VITALITY_LOST = RatesSettings.getFloat("RateVitalityLost", 1);
            RATE_VITALITY_GAIN = RatesSettings.getFloat("RateVitalityGain", 1);
            RATE_RECOVERY_ON_RECONNECT = RatesSettings.getFloat("RateRecoveryOnReconnect", 4);
            RATE_KARMA_LOST = RatesSettings.getFloat("RateKarmaLost", -1);
            if (RATE_KARMA_LOST == -1)
            {
                RATE_KARMA_LOST = RATE_XP;
            }
            RATE_KARMA_EXP_LOST = RatesSettings.getFloat("RateKarmaExpLost", 1);
            RATE_SIEGE_GUARDS_PRICE = RatesSettings.getFloat("RateSiegeGuardsPrice", 1);
            PLAYER_DROP_LIMIT = RatesSettings.getInt("PlayerDropLimit", 3);
            PLAYER_RATE_DROP = RatesSettings.getInt("PlayerRateDrop", 5);
            PLAYER_RATE_DROP_ITEM = RatesSettings.getInt("PlayerRateDropItem", 70);
            PLAYER_RATE_DROP_EQUIP = RatesSettings.getInt("PlayerRateDropEquip", 25);
            PLAYER_RATE_DROP_EQUIP_WEAPON = RatesSettings.getInt("PlayerRateDropEquipWeapon", 5);
            PET_XP_RATE = RatesSettings.getFloat("PetXpRate", 1);
            PET_FOOD_RATE = RatesSettings.getInt("PetFoodRate", 1);
            SINEATER_XP_RATE = RatesSettings.getFloat("SinEaterXpRate", 1);
            KARMA_DROP_LIMIT = RatesSettings.getInt("KarmaDropLimit", 10);
            KARMA_RATE_DROP = RatesSettings.getInt("KarmaRateDrop", 70);
            KARMA_RATE_DROP_ITEM = RatesSettings.getInt("KarmaRateDropItem", 50);
            KARMA_RATE_DROP_EQUIP = RatesSettings.getInt("KarmaRateDropEquip", 40);
            KARMA_RATE_DROP_EQUIP_WEAPON = RatesSettings.getInt("KarmaRateDropEquipWeapon", 10);
           
            RATE_DEATH_DROP_AMOUNT_MULTIPLIER = RatesSettings.getFloat("DeathDropAmountMultiplier", 1);
            RATE_SPOIL_DROP_AMOUNT_MULTIPLIER = RatesSettings.getFloat("SpoilDropAmountMultiplier", 1);
            RATE_HERB_DROP_AMOUNT_MULTIPLIER = RatesSettings.getFloat("HerbDropAmountMultiplier", 1);
            RATE_RAID_DROP_AMOUNT_MULTIPLIER = RatesSettings.getFloat("RaidDropAmountMultiplier", 1);
            RATE_DEATH_DROP_CHANCE_MULTIPLIER = RatesSettings.getFloat("DeathDropChanceMultiplier", 1);
            RATE_SPOIL_DROP_CHANCE_MULTIPLIER = RatesSettings.getFloat("SpoilDropChanceMultiplier", 1);
            RATE_HERB_DROP_CHANCE_MULTIPLIER = RatesSettings.getFloat("HerbDropChanceMultiplier", 1);
            RATE_RAID_DROP_CHANCE_MULTIPLIER = RatesSettings.getFloat("RaidDropChanceMultiplier", 1);
           
            final String[] dropAmountMultiplier = RatesSettings.getString("DropAmountMultiplierByItemId", "").split(";");
            RATE_DROP_AMOUNT_BY_ID = new HashMap<>(dropAmountMultiplier.length);
            if (!dropAmountMultiplier[0].isEmpty())
            {
                for (String item : dropAmountMultiplier)
                {
                    final String[] itemSplit = item.split(",");
                    if (itemSplit.length != 2)
                    {
                        LOGGER.warning("Config.load(): invalid config property -> RateDropItemsById \"" + item + "\"");
                    }
                    else
                    {
                        try
                        {
                            RATE_DROP_AMOUNT_BY_ID.put(Integer.valueOf(itemSplit[0]), Float.valueOf(itemSplit[1]));
                        }
                        catch (NumberFormatException nfe)
                        {
                            if (!item.isEmpty())
                            {
                                LOGGER.warning("Config.load(): invalid config property -> RateDropItemsById \"" + item + "\"");
                            }
                        }
                    }
                }
            }
           
            final String[] dropChanceMultiplier = RatesSettings.getString("DropChanceMultiplierByItemId", "").split(";");
            RATE_DROP_CHANCE_BY_ID = new HashMap<>(dropChanceMultiplier.length);
            if (!dropChanceMultiplier[0].isEmpty())
            {
                for (String item : dropChanceMultiplier)
                {
                    final String[] itemSplit = item.split(",");
                    if (itemSplit.length != 2)
                    {
                        LOGGER.warning("Config.load(): invalid config property -> RateDropItemsById \"" + item + "\"");
                    }
                    else
                    {
                        try
                        {
                            RATE_DROP_CHANCE_BY_ID.put(Integer.valueOf(itemSplit[0]), Float.valueOf(itemSplit[1]));
                        }
                        catch (NumberFormatException nfe)
                        {
                            if (!item.isEmpty())
                            {
                                LOGGER.warning("Config.load(): invalid config property -> RateDropItemsById \"" + item + "\"");
                            }
                        }
                    }
                }
            }
           
            DROP_MAX_OCCURRENCES_NORMAL = RatesSettings.getInt("DropMaxOccurrencesNormal", 2);
            DROP_MAX_OCCURRENCES_RAIDBOSS = RatesSettings.getInt("DropMaxOccurrencesRaidboss", 7);
           
            DROP_ADENA_MIN_LEVEL_DIFFERENCE = RatesSettings.getInt("DropAdenaMinLevelDifference", 8);
            DROP_ADENA_MAX_LEVEL_DIFFERENCE = RatesSettings.getInt("DropAdenaMaxLevelDifference", 15);
            DROP_ADENA_MIN_LEVEL_GAP_CHANCE = RatesSettings.getDouble("DropAdenaMinLevelGapChance", 10);
            DROP_ITEM_MIN_LEVEL_DIFFERENCE = RatesSettings.getInt("DropItemMinLevelDifference", 5);
            DROP_ITEM_MAX_LEVEL_DIFFERENCE = RatesSettings.getInt("DropItemMaxLevelDifference", 10);
            DROP_ITEM_MIN_LEVEL_GAP_CHANCE = RatesSettings.getDouble("DropItemMinLevelGapChance", 10);
           
            // Load PvP config file (if exists)
            final PropertiesParser PVPSettings = new PropertiesParser(PVP_CONFIG_FILE);
           
            KARMA_DROP_GM = PVPSettings.getBoolean("CanGMDropEquipment", false);
            KARMA_AWARD_PK_KILL = PVPSettings.getBoolean("AwardPKKillPVPPoint", false);
            KARMA_PK_LIMIT = PVPSettings.getInt("MinimumPKRequiredToDrop", 5);
            KARMA_NONDROPPABLE_PET_ITEMS = PVPSettings.getString("ListOfPetItems", "2375,3500,3501,3502,4422,4423,4424,4425,6648,6649,6650,9882");
            KARMA_NONDROPPABLE_ITEMS = PVPSettings.getString("ListOfNonDroppableItems", "57,1147,425,1146,461,10,2368,7,6,2370,2369,6842,6611,6612,6613,6614,6615,6616,6617,6618,6619,6620,6621,7694,8181,5575,7694,9388,9389,9390");
           
            String[] karma = KARMA_NONDROPPABLE_PET_ITEMS.split(",");
            KARMA_LIST_NONDROPPABLE_PET_ITEMS = new int[karma.length];
           
            for (int i = 0; i < karma.length; i++)
            {
                KARMA_LIST_NONDROPPABLE_PET_ITEMS[i] = Integer.parseInt(karma[i]);
            }
           
            karma = KARMA_NONDROPPABLE_ITEMS.split(",");
            KARMA_LIST_NONDROPPABLE_ITEMS = new int[karma.length];
           
            for (int i = 0; i < karma.length; i++)
            {
                KARMA_LIST_NONDROPPABLE_ITEMS[i] = Integer.parseInt(karma[i]);
            }
           
            ANTIFEED_ENABLE = PVPSettings.getBoolean("AntiFeedEnable", false);
            ANTIFEED_DUALBOX = PVPSettings.getBoolean("AntiFeedDualbox", true);
            ANTIFEED_DISCONNECTED_AS_DUALBOX = PVPSettings.getBoolean("AntiFeedDisconnectedAsDualbox", true);
            ANTIFEED_INTERVAL = PVPSettings.getInt("AntiFeedInterval", 120) * 1000;
           
            // sorting so binarySearch can be used later
            Arrays.sort(KARMA_LIST_NONDROPPABLE_PET_ITEMS);
            Arrays.sort(KARMA_LIST_NONDROPPABLE_ITEMS);
           
            PVP_NORMAL_TIME = PVPSettings.getInt("PvPVsNormalTime", 120000);
            PVP_PVP_TIME = PVPSettings.getInt("PvPVsPvPTime", 60000);
           
            // Load Olympiad config file (if exists)
            final PropertiesParser Olympiad = new PropertiesParser(OLYMPIAD_CONFIG_FILE);
           
            ALT_OLY_START_TIME = Olympiad.getInt("AltOlyStartTime", 18);
            ALT_OLY_MIN = Olympiad.getInt("AltOlyMin", 0);
            ALT_OLY_MAX_BUFFS = Olympiad.getInt("AltOlyMaxBuffs", 5);
            ALT_OLY_CPERIOD = Olympiad.getLong("AltOlyCPeriod", 21600000);
            ALT_OLY_BATTLE = Olympiad.getLong("AltOlyBattle", 300000);
            ALT_OLY_WPERIOD = Olympiad.getLong("AltOlyWPeriod", 604800000);
            ALT_OLY_VPERIOD = Olympiad.getLong("AltOlyVPeriod", 86400000);
            ALT_OLY_START_POINTS = Olympiad.getInt("AltOlyStartPoints", 10);
            ALT_OLY_WEEKLY_POINTS = Olympiad.getInt("AltOlyWeeklyPoints", 10);
            ALT_OLY_CLASSED = Olympiad.getInt("AltOlyClassedParticipants", 11);
            ALT_OLY_NONCLASSED = Olympiad.getInt("AltOlyNonClassedParticipants", 11);
            ALT_OLY_TEAMS = Olympiad.getInt("AltOlyTeamsParticipants", 6);
            ALT_OLY_REG_DISPLAY = Olympiad.getInt("AltOlyRegistrationDisplayNumber", 100);
            ALT_OLY_CLASSED_REWARD = parseItemsList(Olympiad.getString("AltOlyClassedReward", "13722,50"));
            ALT_OLY_NONCLASSED_REWARD = parseItemsList(Olympiad.getString("AltOlyNonClassedReward", "13722,40"));
            ALT_OLY_TEAM_REWARD = parseItemsList(Olympiad.getString("AltOlyTeamReward", "13722,85"));
            ALT_OLY_COMP_RITEM = Olympiad.getInt("AltOlyCompRewItem", 13722);
            ALT_OLY_MIN_MATCHES = Olympiad.getInt("AltOlyMinMatchesForPoints", 15);
            ALT_OLY_GP_PER_POINT = Olympiad.getInt("AltOlyGPPerPoint", 1000);
            ALT_OLY_HERO_POINTS = Olympiad.getInt("AltOlyHeroPoints", 200);
            ALT_OLY_RANK1_POINTS = Olympiad.getInt("AltOlyRank1Points", 100);
            ALT_OLY_RANK2_POINTS = Olympiad.getInt("AltOlyRank2Points", 75);
            ALT_OLY_RANK3_POINTS = Olympiad.getInt("AltOlyRank3Points", 55);
            ALT_OLY_RANK4_POINTS = Olympiad.getInt("AltOlyRank4Points", 40);
            ALT_OLY_RANK5_POINTS = Olympiad.getInt("AltOlyRank5Points", 30);
            ALT_OLY_MAX_POINTS = Olympiad.getInt("AltOlyMaxPoints", 10);
            ALT_OLY_DIVIDER_CLASSED = Olympiad.getInt("AltOlyDividerClassed", 5);
            ALT_OLY_DIVIDER_NON_CLASSED = Olympiad.getInt("AltOlyDividerNonClassed", 5);
            ALT_OLY_MAX_WEEKLY_MATCHES = Olympiad.getInt("AltOlyMaxWeeklyMatches", 70);
            ALT_OLY_MAX_WEEKLY_MATCHES_NON_CLASSED = Olympiad.getInt("AltOlyMaxWeeklyMatchesNonClassed", 60);
            ALT_OLY_MAX_WEEKLY_MATCHES_CLASSED = Olympiad.getInt("AltOlyMaxWeeklyMatchesClassed", 30);
            ALT_OLY_MAX_WEEKLY_MATCHES_TEAM = Olympiad.getInt("AltOlyMaxWeeklyMatchesTeam", 10);
            ALT_OLY_LOG_FIGHTS = Olympiad.getBoolean("AltOlyLogFights", false);
            ALT_OLY_SHOW_MONTHLY_WINNERS = Olympiad.getBoolean("AltOlyShowMonthlyWinners", true);
            ALT_OLY_ANNOUNCE_GAMES = Olympiad.getBoolean("AltOlyAnnounceGames", true);
            final String[] olyRestrictedItems = Olympiad.getString("AltOlyRestrictedItems", "6611,6612,6613,6614,6615,6616,6617,6618,6619,6620,6621,9388,9389,9390,17049,17050,17051,17052,17053,17054,17055,17056,17057,17058,17059,17060,17061,20759,20775,20776,20777,20778,14774").split(",");
            LIST_OLY_RESTRICTED_ITEMS = new ArrayList<>(olyRestrictedItems.length);
            for (String id : olyRestrictedItems)
            {
                LIST_OLY_RESTRICTED_ITEMS.add(Integer.parseInt(id));
            }
            ALT_OLY_ENCHANT_LIMIT = Olympiad.getInt("AltOlyEnchantLimit", -1);
            ALT_OLY_WAIT_TIME = Olympiad.getInt("AltOlyWaitTime", 120);
            ALT_OLY_USE_CUSTOM_PERIOD_SETTINGS = Olympiad.getBoolean("AltOlyUseCustomPeriodSettings", false);
            ALT_OLY_PERIOD = Olympiad.getString("AltOlyPeriod", "MONTH");
            ALT_OLY_PERIOD_MULTIPLIER = Olympiad.getInt("AltOlyPeriodMultiplier", 1);
            ALT_OLY_COMPETITION_DAYS = new ArrayList<>();
            for (String s : Olympiad.getString("AltOlyCompetitionDays", "1,2,3,4,5,6,7").split(","))
            {
                ALT_OLY_COMPETITION_DAYS.add(Integer.parseInt(s));
            }
           
            final File hexIdFile = new File(HEXID_FILE);
            if (hexIdFile.exists())
            {
                final PropertiesParser hexId = new PropertiesParser(hexIdFile);
               
                if (hexId.containskey("ServerID") && hexId.containskey("HexID"))
                {
                    SERVER_ID = hexId.getInt("ServerID", 1);
                    try
                    {
                        HEX_ID = new BigInteger(hexId.getString("HexID", null), 16).toByteArray();
                    }
                    catch (Exception e)
                    {
                        LOGGER.warning("Could not load HexID file (" + HEXID_FILE + "). Hopefully login will give us one.");
                    }
                }
                else
                {
                    LOGGER.warning("Could not load HexID file (" + HEXID_FILE + "). Hopefully login will give us one.");
                }
            }
            else
            {
                LOGGER.warning("Could not load HexID file (" + HEXID_FILE + "). Hopefully login will give us one.");
            }
           
            // Grand bosses
            final PropertiesParser GrandBossSettings = new PropertiesParser(GRANDBOSS_CONFIG_FILE);
           
            ANTHARAS_WAIT_TIME = GrandBossSettings.getInt("AntharasWaitTime", 30);
            ANTHARAS_SPAWN_INTERVAL = GrandBossSettings.getInt("IntervalOfAntharasSpawn", 264);
            ANTHARAS_SPAWN_RANDOM = GrandBossSettings.getInt("RandomOfAntharasSpawn", 72);
           
            VALAKAS_WAIT_TIME = GrandBossSettings.getInt("ValakasWaitTime", 30);
            VALAKAS_SPAWN_INTERVAL = GrandBossSettings.getInt("IntervalOfValakasSpawn", 264);
            VALAKAS_SPAWN_RANDOM = GrandBossSettings.getInt("RandomOfValakasSpawn", 72);
           
            BAIUM_SPAWN_INTERVAL = GrandBossSettings.getInt("IntervalOfBaiumSpawn", 168);
            BAIUM_SPAWN_RANDOM = GrandBossSettings.getInt("RandomOfBaiumSpawn", 48);
           
            CORE_SPAWN_INTERVAL = GrandBossSettings.getInt("IntervalOfCoreSpawn", 60);
            CORE_SPAWN_RANDOM = GrandBossSettings.getInt("RandomOfCoreSpawn", 24);
           
            ORFEN_SPAWN_INTERVAL = GrandBossSettings.getInt("IntervalOfOrfenSpawn", 48);
            ORFEN_SPAWN_RANDOM = GrandBossSettings.getInt("RandomOfOrfenSpawn", 20);
           
            QUEEN_ANT_SPAWN_INTERVAL = GrandBossSettings.getInt("IntervalOfQueenAntSpawn", 36);
            QUEEN_ANT_SPAWN_RANDOM = GrandBossSettings.getInt("RandomOfQueenAntSpawn", 17);
           
            BELETH_SPAWN_INTERVAL = GrandBossSettings.getInt("IntervalOfBelethSpawn", 192);
            BELETH_SPAWN_RANDOM = GrandBossSettings.getInt("RandomOfBelethSpawn", 148);
            BELETH_MIN_PLAYERS = GrandBossSettings.getInt("BelethMinPlayers", 36);
           
            // Gracia Seeds
            final PropertiesParser GraciaSeedsSettings = new PropertiesParser(GRACIASEEDS_CONFIG_FILE);
           
            // Seed of Destruction
            SOD_TIAT_KILL_COUNT = GraciaSeedsSettings.getInt("TiatKillCountForNextState", 10);
            SOD_STAGE_2_LENGTH = GraciaSeedsSettings.getLong("Stage2Length", 720) * 60000;
           
            MIN_TIAT_PLAYERS = GraciaSeedsSettings.getInt("MinPlayers", 36);
            MAX_TIAT_PLAYERS = GraciaSeedsSettings.getInt("MaxPlayers", 45);
            MIN_TIAT_LEVEL = GraciaSeedsSettings.getInt("MinLevel", 75);
           
            SOI_EKIMUS_KILL_COUNT = GraciaSeedsSettings.getInt("EkimusKillCount", 5);
            EROSION_ATTACK_MIN_PLAYERS = GraciaSeedsSettings.getInt("MinEroAttPlayers", 18);
            EROSION_ATTACK_MAX_PLAYERS = GraciaSeedsSettings.getInt("MaxEroAttPlayers", 27);
            EROSION_DEFENCE_MIN_PLAYERS = GraciaSeedsSettings.getInt("MinEroDefPlayers", 18);
            EROSION_DEFENCE_MAX_PLAYERS = GraciaSeedsSettings.getInt("MaxEroDefPlayers", 27);
            HEART_ATTACK_MIN_PLAYERS = GraciaSeedsSettings.getInt("MinHeaAttPlayers", 18);
            HEART_ATTACK_MAX_PLAYERS = GraciaSeedsSettings.getInt("MaxHeaAttPlayers", 27);
            HEART_DEFENCE_MIN_PLAYERS = GraciaSeedsSettings.getInt("MinHeaDefPlayers", 18);
            HEART_DEFENCE_MAX_PLAYERS = GraciaSeedsSettings.getInt("MaxHeaDefPlayers", 27);
           
            try
            {
                //@formatter:off
                FILTER_LIST = Files.lines(Paths.get(CHAT_FILTER_FILE), StandardCharsets.UTF_8)
                    .map(String::trim)
                    .filter(line -> (!line.isEmpty() && (line.charAt(0) != '#')))
                    .collect(Collectors.toList());
                //@formatter:on
                LOGGER.info("Loaded " + FILTER_LIST.size() + " Filter Words.");
            }
            catch (IOException e)
            {
                LOGGER.log(Level.WARNING, "Error while loading chat filter words!", e);
            }
           
            final PropertiesParser ClanHallSiege = new PropertiesParser(CH_SIEGE_CONFIG_FILE);
           
            CHS_MAX_ATTACKERS = ClanHallSiege.getInt("MaxAttackers", 500);
            CHS_CLAN_MINLEVEL = ClanHallSiege.getInt("MinClanLevel", 4);
            CHS_MAX_FLAGS_PER_CLAN = ClanHallSiege.getInt("MaxFlagsPerClan", 1);
            CHS_ENABLE_FAME = ClanHallSiege.getBoolean("EnableFame", false);
            CHS_FAME_AMOUNT = ClanHallSiege.getInt("FameAmount", 0);
            CHS_FAME_FREQUENCY = ClanHallSiege.getInt("FameFrequency", 0);
           
            final PropertiesParser geoData = new PropertiesParser(GEOENGINE_CONFIG_FILE);
           
            GEODATA_PATH = geoData.getString("GeoDataPath", "./data/geodata/");
            COORD_SYNCHRONIZE = geoData.getInt("CoordSynchronize", -1);
           
            PART_OF_CHARACTER_HEIGHT = geoData.getInt("PartOfCharacterHeight", 75);
            MAX_OBSTACLE_HEIGHT = geoData.getInt("MaxObstacleHeight", 32);
           
            PATHFINDING = geoData.getBoolean("PathFinding", true);
            PATHFIND_BUFFERS = geoData.getString("PathFindBuffers", "100x6;128x6;192x6;256x4;320x4;384x4;500x2");
            BASE_WEIGHT = geoData.getInt("BaseWeight", 10);
            DIAGONAL_WEIGHT = geoData.getInt("DiagonalWeight", 14);
            OBSTACLE_MULTIPLIER = geoData.getInt("ObstacleMultiplier", 10);
            HEURISTIC_WEIGHT = geoData.getInt("HeuristicWeight", 20);
            MAX_ITERATIONS = geoData.getInt("MaxIterations", 3500);
            // Load AllowedPlayerRaces config file (if exists)
            final PropertiesParser AllowedPlayerRaces = new PropertiesParser(CUSTOM_ALLOWED_PLAYER_RACES_CONFIG_FILE);
           
            ALLOW_HUMAN = AllowedPlayerRaces.getBoolean("AllowHuman", true);
            ALLOW_ELF = AllowedPlayerRaces.getBoolean("AllowElf", true);
            ALLOW_DARKELF = AllowedPlayerRaces.getBoolean("AllowDarkElf", true);
            ALLOW_ORC = AllowedPlayerRaces.getBoolean("AllowOrc", true);
            ALLOW_DWARF = AllowedPlayerRaces.getBoolean("AllowDwarf", true);
            ALLOW_KAMAEL = AllowedPlayerRaces.getBoolean("AllowKamael", true);
           
            // Load AutoPotions config file (if exists)
            final PropertiesParser AutoPotions = new PropertiesParser(CUSTOM_AUTO_POTIONS_CONFIG_FILE);
           
            AUTO_POTIONS_ENABLED = AutoPotions.getBoolean("AutoPotionsEnabled", false);
            AUTO_POTIONS_IN_OLYMPIAD = AutoPotions.getBoolean("AutoPotionsInOlympiad", false);
            AUTO_POTION_MIN_LVL = AutoPotions.getInt("AutoPotionMinimumLevel", 1);
            AUTO_CP_ENABLED = AutoPotions.getBoolean("AutoCpEnabled", true);
            AUTO_HP_ENABLED = AutoPotions.getBoolean("AutoHpEnabled", true);
            AUTO_MP_ENABLED = AutoPotions.getBoolean("AutoMpEnabled", true);
            AUTO_CP_PERCENTAGE = AutoPotions.getInt("AutoCpPercentage", 70);
            AUTO_HP_PERCENTAGE = AutoPotions.getInt("AutoHpPercentage", 70);
            AUTO_MP_PERCENTAGE = AutoPotions.getInt("AutoMpPercentage", 70);
            AUTO_CP_ITEM_IDS = new ArrayList<>();
            for (String s : AutoPotions.getString("AutoCpItemIds", "0").split(","))
            {
                AUTO_CP_ITEM_IDS.add(Integer.parseInt(s));
            }
            AUTO_HP_ITEM_IDS = new ArrayList<>();
            for (String s : AutoPotions.getString("AutoHpItemIds", "0").split(","))
            {
                AUTO_HP_ITEM_IDS.add(Integer.parseInt(s));
            }
            AUTO_MP_ITEM_IDS = new ArrayList<>();
            for (String s : AutoPotions.getString("AutoMpItemIds", "0").split(","))
            {
                AUTO_MP_ITEM_IDS.add(Integer.parseInt(s));
            }
           
            // Load Banking config file (if exists)
            final PropertiesParser Banking = new PropertiesParser(CUSTOM_BANKING_CONFIG_FILE);
           
            BANKING_SYSTEM_ENABLED = Banking.getBoolean("BankingEnabled", false);
            BANKING_SYSTEM_GOLDBARS = Banking.getInt("BankingGoldbarCount", 1);
            BANKING_SYSTEM_ADENA = Banking.getInt("BankingAdenaCount", 500000000);
           
            // Load BoostNpcStats config file (if exists)
            final PropertiesParser BoostNpcStats = new PropertiesParser(CUSTOM_NPC_STAT_MULTIPIERS_CONFIG_FILE);
           
            ENABLE_NPC_STAT_MULTIPIERS = BoostNpcStats.getBoolean("EnableNpcStatMultipliers", false);
            MONSTER_HP_MULTIPLIER = BoostNpcStats.getDouble("MonsterHP", 1.0);
            MONSTER_MP_MULTIPLIER = BoostNpcStats.getDouble("MonsterMP", 1.0);
            MONSTER_PATK_MULTIPLIER = BoostNpcStats.getDouble("MonsterPAtk", 1.0);
            MONSTER_MATK_MULTIPLIER = BoostNpcStats.getDouble("MonsterMAtk", 1.0);
            MONSTER_PDEF_MULTIPLIER = BoostNpcStats.getDouble("MonsterPDef", 1.0);
            MONSTER_MDEF_MULTIPLIER = BoostNpcStats.getDouble("MonsterMDef", 1.0);
            MONSTER_AGRRO_RANGE_MULTIPLIER = BoostNpcStats.getDouble("MonsterAggroRange", 1.0);
            MONSTER_CLAN_HELP_RANGE_MULTIPLIER = BoostNpcStats.getDouble("MonsterClanHelpRange", 1.0);
            RAIDBOSS_HP_MULTIPLIER = BoostNpcStats.getDouble("RaidbossHP", 1.0);
            RAIDBOSS_MP_MULTIPLIER = BoostNpcStats.getDouble("RaidbossMP", 1.0);
            RAIDBOSS_PATK_MULTIPLIER = BoostNpcStats.getDouble("RaidbossPAtk", 1.0);
            RAIDBOSS_MATK_MULTIPLIER = BoostNpcStats.getDouble("RaidbossMAtk", 1.0);
            RAIDBOSS_PDEF_MULTIPLIER = BoostNpcStats.getDouble("RaidbossPDef", 1.0);
            RAIDBOSS_MDEF_MULTIPLIER = BoostNpcStats.getDouble("RaidbossMDef", 1.0);
            RAIDBOSS_AGRRO_RANGE_MULTIPLIER = BoostNpcStats.getDouble("RaidbossAggroRange", 1.0);
            RAIDBOSS_CLAN_HELP_RANGE_MULTIPLIER = BoostNpcStats.getDouble("RaidbossClanHelpRange", 1.0);
            GUARD_HP_MULTIPLIER = BoostNpcStats.getDouble("GuardHP", 1.0);
            GUARD_MP_MULTIPLIER = BoostNpcStats.getDouble("GuardMP", 1.0);
            GUARD_PATK_MULTIPLIER = BoostNpcStats.getDouble("GuardPAtk", 1.0);
            GUARD_MATK_MULTIPLIER = BoostNpcStats.getDouble("GuardMAtk", 1.0);
            GUARD_PDEF_MULTIPLIER = BoostNpcStats.getDouble("GuardPDef", 1.0);
            GUARD_MDEF_MULTIPLIER = BoostNpcStats.getDouble("GuardMDef", 1.0);
            GUARD_AGRRO_RANGE_MULTIPLIER = BoostNpcStats.getDouble("GuardAggroRange", 1.0);
            GUARD_CLAN_HELP_RANGE_MULTIPLIER = BoostNpcStats.getDouble("GuardClanHelpRange", 1.0);
            DEFENDER_HP_MULTIPLIER = BoostNpcStats.getDouble("DefenderHP", 1.0);
            DEFENDER_MP_MULTIPLIER = BoostNpcStats.getDouble("DefenderMP", 1.0);
            DEFENDER_PATK_MULTIPLIER = BoostNpcStats.getDouble("DefenderPAtk", 1.0);
            DEFENDER_MATK_MULTIPLIER = BoostNpcStats.getDouble("DefenderMAtk", 1.0);
            DEFENDER_PDEF_MULTIPLIER = BoostNpcStats.getDouble("DefenderPDef", 1.0);
            DEFENDER_MDEF_MULTIPLIER = BoostNpcStats.getDouble("DefenderMDef", 1.0);
            DEFENDER_AGRRO_RANGE_MULTIPLIER = BoostNpcStats.getDouble("DefenderAggroRange", 1.0);
            DEFENDER_CLAN_HELP_RANGE_MULTIPLIER = BoostNpcStats.getDouble("DefenderClanHelpRange", 1.0);
           
            // Load ChampionMonster config file (if exists)
            final PropertiesParser ChampionMonster = new PropertiesParser(CUSTOM_CHAMPION_MONSTERS_CONFIG_FILE);
           
            CHAMPION_ENABLE = ChampionMonster.getBoolean("ChampionEnable", false);
            CHAMPION_PASSIVE = ChampionMonster.getBoolean("ChampionPassive", false);
            CHAMPION_FREQUENCY = ChampionMonster.getInt("ChampionFrequency", 0);
            CHAMP_TITLE = ChampionMonster.getString("ChampionTitle", "Champion");
            SHOW_CHAMPION_AURA = ChampionMonster.getBoolean("ChampionAura", true);
            CHAMP_MIN_LVL = ChampionMonster.getInt("ChampionMinLevel", 20);
            CHAMP_MAX_LVL = ChampionMonster.getInt("ChampionMaxLevel", 60);
            CHAMPION_HP = ChampionMonster.getInt("ChampionHp", 7);
            CHAMPION_HP_REGEN = ChampionMonster.getFloat("ChampionHpRegen", 1);
            CHAMPION_REWARDS_EXP_SP = ChampionMonster.getFloat("ChampionRewardsExpSp", 8);
            CHAMPION_REWARDS_CHANCE = ChampionMonster.getFloat("ChampionRewardsChance", 8);
            CHAMPION_REWARDS_AMOUNT = ChampionMonster.getFloat("ChampionRewardsAmount", 1);
            CHAMPION_ADENAS_REWARDS_CHANCE = ChampionMonster.getFloat("ChampionAdenasRewardsChance", 1);
            CHAMPION_ADENAS_REWARDS_AMOUNT = ChampionMonster.getFloat("ChampionAdenasRewardsAmount", 1);
            CHAMPION_ATK = ChampionMonster.getFloat("ChampionAtk", 1);
            CHAMPION_SPD_ATK = ChampionMonster.getFloat("ChampionSpdAtk", 1);
            CHAMPION_REWARD_LOWER_LVL_ITEM_CHANCE = ChampionMonster.getInt("ChampionRewardLowerLvlItemChance", 0);
            CHAMPION_REWARD_HIGHER_LVL_ITEM_CHANCE = ChampionMonster.getInt("ChampionRewardHigherLvlItemChance", 0);
            CHAMPION_REWARD_ID = ChampionMonster.getInt("ChampionRewardItemID", 6393);
            CHAMPION_REWARD_QTY = ChampionMonster.getInt("ChampionRewardItemQty", 1);
            CHAMPION_ENABLE_VITALITY = ChampionMonster.getBoolean("ChampionEnableVitality", false);
            CHAMPION_ENABLE_IN_INSTANCES = ChampionMonster.getBoolean("ChampionEnableInInstances", false);
           
            // Load ChatModeration config file (if exists)
            final PropertiesParser ChatModeration = new PropertiesParser(CUSTOM_CHAT_MODERATION_CONFIG_FILE);
           
            CHAT_ADMIN = ChatModeration.getBoolean("ChatAdmin", true);
           
            // Load CommunityBoard config file (if exists)
            final PropertiesParser CommunityBoard = new PropertiesParser(CUSTOM_COMMUNITY_BOARD_CONFIG_FILE);
           
            CUSTOM_CB_ENABLED = CommunityBoard.getBoolean("CustomCommunityBoard", false);
            COMMUNITYBOARD_CURRENCY = CommunityBoard.getInt("CommunityCurrencyId", 57);
            COMMUNITYBOARD_ENABLE_MULTISELLS = CommunityBoard.getBoolean("CommunityEnableMultisells", true);
            COMMUNITYBOARD_ENABLE_TELEPORTS = CommunityBoard.getBoolean("CommunityEnableTeleports", true);
            COMMUNITYBOARD_ENABLE_BUFFS = CommunityBoard.getBoolean("CommunityEnableBuffs", true);
            COMMUNITYBOARD_ENABLE_HEAL = CommunityBoard.getBoolean("CommunityEnableHeal", true);
            COMMUNITYBOARD_TELEPORT_PRICE = CommunityBoard.getInt("CommunityTeleportPrice", 0);
            COMMUNITYBOARD_BUFF_PRICE = CommunityBoard.getInt("CommunityBuffPrice", 0);
            COMMUNITYBOARD_HEAL_PRICE = CommunityBoard.getInt("CommunityHealPrice", 0);
            COMMUNITYBOARD_COMBAT_DISABLED = CommunityBoard.getBoolean("CommunityCombatDisabled", true);
            COMMUNITYBOARD_KARMA_DISABLED = CommunityBoard.getBoolean("CommunityKarmaDisabled", true);
            COMMUNITYBOARD_CAST_ANIMATIONS = CommunityBoard.getBoolean("CommunityCastAnimations", false);
            COMMUNITY_PREMIUM_SYSTEM_ENABLED = CommunityBoard.getBoolean("CommunityPremiumSystem", false);
            COMMUNITY_PREMIUM_COIN_ID = CommunityBoard.getInt("CommunityPremiumBuyCoinId", 57);
            COMMUNITY_PREMIUM_PRICE_PER_DAY = CommunityBoard.getInt("CommunityPremiumPricePerDay", 1000000);
            final String[] allowedBuffs = CommunityBoard.getString("CommunityAvailableBuffs", "").split(",");
            COMMUNITY_AVAILABLE_BUFFS = new ArrayList<>(allowedBuffs.length);
            for (String s : allowedBuffs)
            {
                COMMUNITY_AVAILABLE_BUFFS.add(Integer.parseInt(s));
            }
            final String[] availableTeleports = CommunityBoard.getString("CommunityTeleportList", "").split(";");
            COMMUNITY_AVAILABLE_TELEPORTS = new HashMap<>(availableTeleports.length);
            for (String s : availableTeleports)
            {
                final String splitInfo[] = s.split(",");
                COMMUNITY_AVAILABLE_TELEPORTS.put(splitInfo[0], new Location(Integer.parseInt(splitInfo[1]), Integer.parseInt(splitInfo[2]), Integer.parseInt(splitInfo[3])));
            }
           
            // Load DualboxCheck config file (if exists)
            final PropertiesParser DualboxCheck = new PropertiesParser(CUSTOM_DUALBOX_CHECK_CONFIG_FILE);
           
            DUALBOX_CHECK_MAX_PLAYERS_PER_IP = DualboxCheck.getInt("DualboxCheckMaxPlayersPerIP", 0);
            DUALBOX_CHECK_MAX_OLYMPIAD_PARTICIPANTS_PER_IP = DualboxCheck.getInt("DualboxCheckMaxOlympiadParticipantsPerIP", 0);
            DUALBOX_CHECK_MAX_L2EVENT_PARTICIPANTS_PER_IP = DualboxCheck.getInt("DualboxCheckMaxL2EventParticipantsPerIP", 0);
            DUALBOX_COUNT_OFFLINE_TRADERS = DualboxCheck.getBoolean("DualboxCountOfflineTraders", false);
            final String[] dualboxCheckWhiteList = DualboxCheck.getString("DualboxCheckWhitelist", "127.0.0.1,0").split(";");
            DUALBOX_CHECK_WHITELIST = new HashMap<>(dualboxCheckWhiteList.length);
            for (String entry : dualboxCheckWhiteList)
            {
                final String[] entrySplit = entry.split(",");
                if (entrySplit.length != 2)
                {
                    LOGGER.warning("DualboxCheck[Config.load()]: invalid config property -> DualboxCheckWhitelist \"" + entry + "\"");
                }
                else
                {
                    try
                    {
                        int num = Integer.parseInt(entrySplit[1]);
                        num = num == 0 ? -1 : num;
                        DUALBOX_CHECK_WHITELIST.put(InetAddress.getByName(entrySplit[0]).hashCode(), num);
                    }
                    catch (UnknownHostException e)
                    {
                        LOGGER.warning("DualboxCheck[Config.load()]: invalid address -> DualboxCheckWhitelist \"" + entrySplit[0] + "\"");
                    }
                    catch (NumberFormatException e)
                    {
                        LOGGER.warning("DualboxCheck[Config.load()]: invalid number -> DualboxCheckWhitelist \"" + entrySplit[1] + "\"");
                    }
                }
            }
           
            // Load FactionSystem config file (if exists)
            final PropertiesParser FactionSystem = new PropertiesParser(CUSTOM_FACTION_SYSTEM_CONFIG_FILE);
           
            String[] tempString;
            FACTION_SYSTEM_ENABLED = Boolean.valueOf(FactionSystem.getBoolean("EnableFactionSystem", false));
            tempString = FactionSystem.getString("StartingLocation", "85332,16199,-1252").split(",");
            FACTION_STARTING_LOCATION = new Location(Integer.parseInt(tempString[0]), Integer.parseInt(tempString[1]), Integer.parseInt(tempString[2]));
            FACTION_MANAGER_NPCID = FactionSystem.getInt("FactionManagerNpcId", 500);
            tempString = FactionSystem.getString("ManagerSpawnLocation", "85712,15974,-1260,26808").split(",");
            FACTION_MANAGER_LOCATION = new Location(Integer.parseInt(tempString[0]), Integer.parseInt(tempString[1]), Integer.parseInt(tempString[2]), tempString[3] != null ? Integer.parseInt(tempString[3]) : 0);
            tempString = FactionSystem.getString("GoodBaseLocation", "45306,48878,-3058").split(",");
            FACTION_GOOD_BASE_LOCATION = new Location(Integer.parseInt(tempString[0]), Integer.parseInt(tempString[1]), Integer.parseInt(tempString[2]));
            tempString = FactionSystem.getString("EvilBaseLocation", "-44037,-113283,-237").split(",");
            FACTION_EVIL_BASE_LOCATION = new Location(Integer.parseInt(tempString[0]), Integer.parseInt(tempString[1]), Integer.parseInt(tempString[2]));
            FACTION_GOOD_TEAM_NAME = FactionSystem.getString("GoodTeamName", "Good");
            FACTION_EVIL_TEAM_NAME = FactionSystem.getString("EvilTeamName", "Evil");
            FACTION_GOOD_NAME_COLOR = Integer.decode("0x" + FactionSystem.getString("GoodNameColor", "00FF00"));
            FACTION_EVIL_NAME_COLOR = Integer.decode("0x" + FactionSystem.getString("EvilNameColor", "0000FF"));
            FACTION_GUARDS_ENABLED = FactionSystem.getBoolean("EnableFactionGuards", true);
            FACTION_GOOD_GUARD_NPCID = FactionSystem.getInt("GoodGuardNpcId", 501);
            FACTION_EVIL_GUARD_NPCID = FactionSystem.getInt("EvilGuardNpcId", 502);
            FACTION_RESPAWN_AT_BASE = FactionSystem.getBoolean("RespawnAtFactionBase", true);
            FACTION_AUTO_NOBLESS = FactionSystem.getBoolean("FactionAutoNobless", false);
            FACTION_SPECIFIC_CHAT = FactionSystem.getBoolean("EnableFactionChat", true);
            FACTION_BALANCE_ONLINE_PLAYERS = FactionSystem.getBoolean("BalanceOnlinePlayers", true);
            FACTION_BALANCE_PLAYER_EXCEED_LIMIT = FactionSystem.getInt("BalancePlayerExceedLimit", 20);
           
            // Load FakePlayers config file (if exists)
            final PropertiesParser FakePlayers = new PropertiesParser(CUSTOM_FAKE_PLAYERS_CONFIG_FILE);
            FAKE_PLAYERS_ENABLED = Boolean.valueOf(FakePlayers.getBoolean("EnableFakePlayers", false));
            FAKE_PLAYER_CHAT = Boolean.valueOf(FakePlayers.getBoolean("FakePlayerChat", false));
            FAKE_PLAYER_USE_SHOTS = Boolean.valueOf(FakePlayers.getBoolean("FakePlayerUseShots", false));
            FAKE_PLAYER_KILL_PVP = Boolean.valueOf(FakePlayers.getBoolean("FakePlayerKillsRewardPvP", false));
            FAKE_PLAYER_KILL_KARMA = Boolean.valueOf(FakePlayers.getBoolean("FakePlayerUnflaggedKillsKarma", false));
            FAKE_PLAYER_AGGRO_MONSTERS = Boolean.valueOf(FakePlayers.getBoolean("FakePlayerAggroMonsters", false));
            FAKE_PLAYER_AGGRO_PLAYERS = Boolean.valueOf(FakePlayers.getBoolean("FakePlayerAggroPlayers", false));
            FAKE_PLAYER_AGGRO_FPC = Boolean.valueOf(FakePlayers.getBoolean("FakePlayerAggroFPC", false));
            FAKE_PLAYER_CAN_DROP_ITEMS = Boolean.valueOf(FakePlayers.getBoolean("FakePlayerCanDropItems", false));
            FAKE_PLAYER_CAN_PICKUP = Boolean.valueOf(FakePlayers.getBoolean("FakePlayerCanPickup", false));
           
            // Load FindPvP config file (if exists)
            final PropertiesParser FindPvP = new PropertiesParser(CUSTOM_FIND_PVP_CONFIG_FILE);
           
            ENABLE_FIND_PVP = FindPvP.getBoolean("EnableFindPvP", false);
           
            // Load HellboundStatus config file (if exists)
            final PropertiesParser HellboundStatus = new PropertiesParser(CUSTOM_HELLBOUND_STATUS_CONFIG_FILE);
           
            HELLBOUND_STATUS = HellboundStatus.getBoolean("HellboundStatus", false);
           
            // Load MultilingualSupport config file (if exists)
            final PropertiesParser MultilingualSupport = new PropertiesParser(CUSTOM_MULTILANGUAL_SUPPORT_CONFIG_FILE);
           
            MULTILANG_DEFAULT = MultilingualSupport.getString("MultiLangDefault", "en");
            MULTILANG_ENABLE = MultilingualSupport.getBoolean("MultiLangEnable", false);
            String[] allowed = MultilingualSupport.getString("MultiLangAllowed", MULTILANG_DEFAULT).split(";");
            MULTILANG_ALLOWED = new ArrayList<>(allowed.length);
            for (String lang : allowed)
            {
                MULTILANG_ALLOWED.add(lang);
            }
            if (!MULTILANG_ALLOWED.contains(MULTILANG_DEFAULT))
            {
                LOGGER.warning("MultiLang[Config.load()]: default language: " + MULTILANG_DEFAULT + " is not in allowed list !");
            }
            MULTILANG_VOICED_ALLOW = MultilingualSupport.getBoolean("MultiLangVoiceCommand", true);
            MULTILANG_SM_ENABLE = MultilingualSupport.getBoolean("MultiLangSystemMessageEnable", false);
            allowed = MultilingualSupport.getString("MultiLangSystemMessageAllowed", "").split(";");
            MULTILANG_SM_ALLOWED = new ArrayList<>(allowed.length);
            for (String lang : allowed)
            {
                if (!lang.isEmpty())
                {
                    MULTILANG_SM_ALLOWED.add(lang);
                }
            }
            MULTILANG_NS_ENABLE = MultilingualSupport.getBoolean("MultiLangNpcStringEnable", false);
            allowed = MultilingualSupport.getString("MultiLangNpcStringAllowed", "").split(";");
            MULTILANG_NS_ALLOWED = new ArrayList<>(allowed.length);
            for (String lang : allowed)
            {
                if (!lang.isEmpty())
                {
                    MULTILANG_NS_ALLOWED.add(lang);
                }
            }
           
            // Load OfflineTrade config file (if exists)
            final PropertiesParser OfflineTrade = new PropertiesParser(CUSTOM_OFFLINE_TRADE_CONFIG_FILE);
           
            OFFLINE_TRADE_ENABLE = OfflineTrade.getBoolean("OfflineTradeEnable", false);
            OFFLINE_CRAFT_ENABLE = OfflineTrade.getBoolean("OfflineCraftEnable", false);
            OFFLINE_MODE_IN_PEACE_ZONE = OfflineTrade.getBoolean("OfflineModeInPeaceZone", false);
            OFFLINE_MODE_NO_DAMAGE = OfflineTrade.getBoolean("OfflineModeNoDamage", false);
            OFFLINE_SET_NAME_COLOR = OfflineTrade.getBoolean("OfflineSetNameColor", false);
            OFFLINE_NAME_COLOR = Integer.decode("0x" + OfflineTrade.getString("OfflineNameColor", "808080"));
            OFFLINE_FAME = OfflineTrade.getBoolean("OfflineFame", true);
            RESTORE_OFFLINERS = OfflineTrade.getBoolean("RestoreOffliners", false);
            OFFLINE_MAX_DAYS = OfflineTrade.getInt("OfflineMaxDays", 10);
            STORE_OFFLINE_TRADE_IN_REALTIME = OfflineTrade.getBoolean("StoreOfflineTradeInRealtime", true);
            OFFLINE_DISCONNECT_FINISHED = OfflineTrade.getBoolean("OfflineDisconnectFinished", true);
           
            // Load PasswordChange config file (if exists)
            final PropertiesParser PasswordChange = new PropertiesParser(CUSTOM_PASSWORD_CHANGE_CONFIG_FILE);
           
            ALLOW_CHANGE_PASSWORD = PasswordChange.getBoolean("AllowChangePassword", false);
           
            // Load PremiumSystem config file (if exists)
            final PropertiesParser PremiumSystem = new PropertiesParser(CUSTOM_PREMIUM_SYSTEM_CONFIG_FILE);
           
            PREMIUM_SYSTEM_ENABLED = PremiumSystem.getBoolean("EnablePremiumSystem", false);
            PREMIUM_RATE_XP = PremiumSystem.getFloat("PremiumRateXp", 2);
            PREMIUM_RATE_SP = PremiumSystem.getFloat("PremiumRateSp", 2);
            PREMIUM_RATE_DROP_CHANCE = PremiumSystem.getFloat("PremiumRateDropChance", 2);
            PREMIUM_RATE_DROP_AMOUNT = PremiumSystem.getFloat("PremiumRateDropAmount", 1);
            PREMIUM_RATE_SPOIL_CHANCE = PremiumSystem.getFloat("PremiumRateSpoilChance", 2);
            PREMIUM_RATE_SPOIL_AMOUNT = PremiumSystem.getFloat("PremiumRateSpoilAmount", 1);
            final String[] premiumDropChanceMultiplier = PremiumSystem.getString("PremiumRateDropChanceByItemId", "").split(";");
            PREMIUM_RATE_DROP_CHANCE_BY_ID = new HashMap<>(premiumDropChanceMultiplier.length);
            if (!premiumDropChanceMultiplier[0].isEmpty())
            {
                for (String item : premiumDropChanceMultiplier)
                {
                    final String[] itemSplit = item.split(",");
                    if (itemSplit.length != 2)
                    {
                        LOGGER.warning("Config.load(): invalid config property -> PremiumRateDropChanceByItemId \"" + item + "\"");
                    }
                    else
                    {
                        try
                        {
                            PREMIUM_RATE_DROP_CHANCE_BY_ID.put(Integer.valueOf(itemSplit[0]), Float.valueOf(itemSplit[1]));
                        }
                        catch (NumberFormatException nfe)
                        {
                            if (!item.isEmpty())
                            {
                                LOGGER.warning("Config.load(): invalid config property -> PremiumRateDropChanceByItemId \"" + item + "\"");
                            }
                        }
                    }
                }
            }
            final String[] premiumDropAmountMultiplier = PremiumSystem.getString("PremiumRateDropAmountByItemId", "").split(";");
            PREMIUM_RATE_DROP_AMOUNT_BY_ID = new HashMap<>(premiumDropAmountMultiplier.length);
            if (!premiumDropAmountMultiplier[0].isEmpty())
            {
                for (String item : premiumDropAmountMultiplier)
                {
                    final String[] itemSplit = item.split(",");
                    if (itemSplit.length != 2)
                    {
                        LOGGER.warning("Config.load(): invalid config property -> PremiumRateDropAmountByItemId \"" + item + "\"");
                    }
                    else
                    {
                        try
                        {
                            PREMIUM_RATE_DROP_AMOUNT_BY_ID.put(Integer.valueOf(itemSplit[0]), Float.valueOf(itemSplit[1]));
                        }
                        catch (NumberFormatException nfe)
                        {
                            if (!item.isEmpty())
                            {
                                LOGGER.warning("Config.load(): invalid config property -> PremiumRateDropAmountByItemId \"" + item + "\"");
                            }
                        }
                    }
                }
            }
           
            // Load PrivateStoreRange config file (if exists)
            final PropertiesParser PrivateStoreRange = new PropertiesParser(CUSTOM_PRIVATE_STORE_RANGE_CONFIG_FILE);
           
            SHOP_MIN_RANGE_FROM_PLAYER = PrivateStoreRange.getInt("ShopMinRangeFromPlayer", 50);
            SHOP_MIN_RANGE_FROM_NPC = PrivateStoreRange.getInt("ShopMinRangeFromNpc", 100);
           
            // Load PvpAnnounce config file (if exists)
            final PropertiesParser PvpAnnounce = new PropertiesParser(CUSTOM_PVP_ANNOUNCE_CONFIG_FILE);
           
            ANNOUNCE_PK_PVP = PvpAnnounce.getBoolean("AnnouncePkPvP", false);
            ANNOUNCE_PK_PVP_NORMAL_MESSAGE = PvpAnnounce.getBoolean("AnnouncePkPvPNormalMessage", true);
            ANNOUNCE_PK_MSG = PvpAnnounce.getString("AnnouncePkMsg", "$killer has slaughtered $target");
            ANNOUNCE_PVP_MSG = PvpAnnounce.getString("AnnouncePvpMsg", "$killer has defeated $target");
           
            // Load PvpRewardItem config file (if exists)
            final PropertiesParser PvpRewardItem = new PropertiesParser(CUSTOM_PVP_REWARD_ITEM_CONFIG_FILE);
           
            REWARD_PVP_ITEM = PvpRewardItem.getBoolean("RewardPvpItem", false);
            REWARD_PVP_ITEM_ID = PvpRewardItem.getInt("RewardPvpItemId", 57);
            REWARD_PVP_ITEM_AMOUNT = PvpRewardItem.getInt("RewardPvpItemAmount", 1000);
            REWARD_PVP_ITEM_MESSAGE = PvpRewardItem.getBoolean("RewardPvpItemMessage", true);
            REWARD_PK_ITEM = PvpRewardItem.getBoolean("RewardPkItem", false);
            REWARD_PK_ITEM_ID = PvpRewardItem.getInt("RewardPkItemId", 57);
            REWARD_PK_ITEM_AMOUNT = PvpRewardItem.getInt("RewardPkItemAmount", 500);
            REWARD_PK_ITEM_MESSAGE = PvpRewardItem.getBoolean("RewardPkItemMessage", true);
            DISABLE_REWARDS_IN_INSTANCES = PvpRewardItem.getBoolean("DisableRewardsInInstances", true);
            DISABLE_REWARDS_IN_PVP_ZONES = PvpRewardItem.getBoolean("DisableRewardsInPvpZones", true);
           
            // Load PvpRewardItem config file (if exists)
            final PropertiesParser PvpTitleColor = new PropertiesParser(CUSTOM_PVP_TITLE_CONFIG_FILE);
           
            PVP_COLOR_SYSTEM_ENABLED = PvpTitleColor.getBoolean("EnablePvPColorSystem", false);
            PVP_AMOUNT1 = PvpTitleColor.getInt("PvpAmount1", 500);
            PVP_AMOUNT2 = PvpTitleColor.getInt("PvpAmount2", 1000);
            PVP_AMOUNT3 = PvpTitleColor.getInt("PvpAmount3", 1500);
            PVP_AMOUNT4 = PvpTitleColor.getInt("PvpAmount4", 2500);
            PVP_AMOUNT5 = PvpTitleColor.getInt("PvpAmount5", 5000);
            NAME_COLOR_FOR_PVP_AMOUNT1 = Integer.decode("0x" + PvpTitleColor.getString("ColorForAmount1", "00FF00"));
            NAME_COLOR_FOR_PVP_AMOUNT2 = Integer.decode("0x" + PvpTitleColor.getString("ColorForAmount2", "00FF00"));
            NAME_COLOR_FOR_PVP_AMOUNT3 = Integer.decode("0x" + PvpTitleColor.getString("ColorForAmount3", "00FF00"));
            NAME_COLOR_FOR_PVP_AMOUNT4 = Integer.decode("0x" + PvpTitleColor.getString("ColorForAmount4", "00FF00"));
            NAME_COLOR_FOR_PVP_AMOUNT5 = Integer.decode("0x" + PvpTitleColor.getString("ColorForAmount5", "00FF00"));
            TITLE_FOR_PVP_AMOUNT1 = PvpTitleColor.getString("PvPTitleForAmount1", "Title");
            TITLE_FOR_PVP_AMOUNT2 = PvpTitleColor.getString("PvPTitleForAmount2", "Title");
            TITLE_FOR_PVP_AMOUNT3 = PvpTitleColor.getString("PvPTitleForAmount3", "Title");
            TITLE_FOR_PVP_AMOUNT4 = PvpTitleColor.getString("PvPTitleForAmount4", "Title");
            TITLE_FOR_PVP_AMOUNT5 = PvpTitleColor.getString("PvPTitleForAmount5", "Title");
           
            // Load RandomSpawns config file (if exists)
            final PropertiesParser RandomSpawns = new PropertiesParser(CUSTOM_RANDOM_SPAWNS_CONFIG_FILE);
           
            ENABLE_RANDOM_MONSTER_SPAWNS = RandomSpawns.getBoolean("EnableRandomMonsterSpawns", false);
            MOB_MAX_SPAWN_RANGE = RandomSpawns.getInt("MaxSpawnMobRange", 150);
            MOB_MIN_SPAWN_RANGE = MOB_MAX_SPAWN_RANGE * -1;
            if (ENABLE_RANDOM_MONSTER_SPAWNS)
            {
                final String[] mobsIds = RandomSpawns.getString("MobsSpawnNotRandom", "18812,18813,18814,22138").split(",");
                MOBS_LIST_NOT_RANDOM = new ArrayList<>(mobsIds.length);
                for (String id : mobsIds)
                {
                    MOBS_LIST_NOT_RANDOM.add(Integer.valueOf(id));
                }
            }
           
            // Load ScreenWelcomeMessage config file (if exists)
            final PropertiesParser ScreenWelcomeMessage = new PropertiesParser(CUSTOM_SCREEN_WELCOME_MESSAGE_CONFIG_FILE);
           
            WELCOME_MESSAGE_ENABLED = ScreenWelcomeMessage.getBoolean("ScreenWelcomeMessageEnable", false);
            WELCOME_MESSAGE_TEXT = ScreenWelcomeMessage.getString("ScreenWelcomeMessageText", "Welcome to our server!");
            WELCOME_MESSAGE_TIME = ScreenWelcomeMessage.getInt("ScreenWelcomeMessageTime", 10) * 1000;
           
            // Load SellBuffs config file (if exists)
            final PropertiesParser SellBuffs = new PropertiesParser(CUSTOM_SELL_BUFFS_CONFIG_FILE);
           
            SELLBUFF_ENABLED = SellBuffs.getBoolean("SellBuffEnable", false);
            SELLBUFF_MP_MULTIPLER = SellBuffs.getInt("MpCostMultipler", 1);
            SELLBUFF_PAYMENT_ID = SellBuffs.getInt("PaymentID", 57);
            SELLBUFF_MIN_PRICE = SellBuffs.getLong("MinimalPrice", 100000);
            SELLBUFF_MAX_PRICE = SellBuffs.getLong("MaximalPrice", 100000000);
            SELLBUFF_MAX_BUFFS = SellBuffs.getInt("MaxBuffs", 15);
           
            // Load ServerTime config file (if exists)
            final PropertiesParser ServerTime = new PropertiesParser(CUSTOM_SERVER_TIME_CONFIG_FILE);
           
            DISPLAY_SERVER_TIME = ServerTime.getBoolean("DisplayServerTime", false);
           
            // Load SchemeBuffer config file (if exists)
            final PropertiesParser SchemeBuffer = new PropertiesParser(CUSTOM_SCHEME_BUFFER_CONFIG_FILE);
           
            BUFFER_MAX_SCHEMES = SchemeBuffer.getInt("BufferMaxSchemesPerChar", 4);
            BUFFER_STATIC_BUFF_COST = SchemeBuffer.getInt("BufferStaticCostPerBuff", -1);
           
            // Load StartingLocation config file (if exists)
            final PropertiesParser StartingLocation = new PropertiesParser(CUSTOM_STARTING_LOCATION_CONFIG_FILE);
           
            CUSTOM_STARTING_LOC = StartingLocation.getBoolean("CustomStartingLocation", false);
            CUSTOM_STARTING_LOC_X = StartingLocation.getInt("CustomStartingLocX", 83020);
            CUSTOM_STARTING_LOC_Y = StartingLocation.getInt("CustomStartingLocY", 147880);
            CUSTOM_STARTING_LOC_Z = StartingLocation.getInt("CustomStartingLocZ", -3469);
           
            // Load TeamVersusTeam config file (if exists)
            final PropertiesParser TeamVersusTeam = new PropertiesParser(CUSTOM_TVT_CONFIG_FILE);
           
            TVT_EVENT_ENABLED = TeamVersusTeam.getBoolean("TvTEventEnabled", false);
            TVT_EVENT_IN_INSTANCE = TeamVersusTeam.getBoolean("TvTEventInInstance", false);
            TVT_EVENT_INSTANCE_ID = TeamVersusTeam.getInt("TvTEventInstanceId", 3049);
            TVT_EVENT_INTERVAL = TeamVersusTeam.getString("TvTEventInterval", "20:00").split(",");
            TVT_EVENT_PARTICIPATION_TIME = TeamVersusTeam.getInt("TvTEventParticipationTime", 3600);
            TVT_EVENT_RUNNING_TIME = TeamVersusTeam.getInt("TvTEventRunningTime", 1800);
            TVT_EVENT_PARTICIPATION_NPC_ID = TeamVersusTeam.getInt("TvTEventParticipationNpcId", 0);
           
            if (TVT_EVENT_PARTICIPATION_NPC_ID == 0)
            {
                TVT_EVENT_ENABLED = false;
                LOGGER.warning("TvTEventEngine[Config.load()]: invalid config property -> TvTEventParticipationNpcId");
            }
            else
            {
                String[] tvtNpcCoords = TeamVersusTeam.getString("TvTEventParticipationNpcCoordinates", "0,0,0").split(",");
                if (tvtNpcCoords.length < 3)
                {
                    TVT_EVENT_ENABLED = false;
                    LOGGER.warning("TvTEventEngine[Config.load()]: invalid config property -> TvTEventParticipationNpcCoordinates");
                }
                else
                {
                    TVT_EVENT_REWARDS = new ArrayList<>();
                    TVT_DOORS_IDS_TO_OPEN = new ArrayList<>();
                    TVT_DOORS_IDS_TO_CLOSE = new ArrayList<>();
                    TVT_EVENT_PARTICIPATION_NPC_COORDINATES = new int[4];
                    TVT_EVENT_TEAM_1_COORDINATES = new int[3];
                    TVT_EVENT_TEAM_2_COORDINATES = new int[3];
                    TVT_EVENT_PARTICIPATION_NPC_COORDINATES[0] = Integer.parseInt(tvtNpcCoords[0]);
                    TVT_EVENT_PARTICIPATION_NPC_COORDINATES[1] = Integer.parseInt(tvtNpcCoords[1]);
                    TVT_EVENT_PARTICIPATION_NPC_COORDINATES[2] = Integer.parseInt(tvtNpcCoords[2]);
                    if (tvtNpcCoords.length == 4)
                    {
                        TVT_EVENT_PARTICIPATION_NPC_COORDINATES[3] = Integer.parseInt(tvtNpcCoords[3]);
                    }
                    TVT_EVENT_MIN_PLAYERS_IN_TEAMS = TeamVersusTeam.getInt("TvTEventMinPlayersInTeams", 1);
                    TVT_EVENT_MAX_PLAYERS_IN_TEAMS = TeamVersusTeam.getInt("TvTEventMaxPlayersInTeams", 20);
                    TVT_EVENT_MIN_LVL = TeamVersusTeam.getByte("TvTEventMinPlayerLevel", (byte) 1);
                    TVT_EVENT_MAX_LVL = TeamVersusTeam.getByte("TvTEventMaxPlayerLevel", (byte) 80);
                    TVT_EVENT_RESPAWN_TELEPORT_DELAY = TeamVersusTeam.getInt("TvTEventRespawnTeleportDelay", 20);
                    TVT_EVENT_START_LEAVE_TELEPORT_DELAY = TeamVersusTeam.getInt("TvTEventStartLeaveTeleportDelay", 20);
                    TVT_EVENT_EFFECTS_REMOVAL = TeamVersusTeam.getInt("TvTEventEffectsRemoval", 0);
                    TVT_EVENT_MAX_PARTICIPANTS_PER_IP = TeamVersusTeam.getInt("TvTEventMaxParticipantsPerIP", 0);
                    TVT_ALLOW_VOICED_COMMAND = TeamVersusTeam.getBoolean("TvTAllowVoicedInfoCommand", false);
                    TVT_EVENT_TEAM_1_NAME = TeamVersusTeam.getString("TvTEventTeam1Name", "Team1");
                    tvtNpcCoords = TeamVersusTeam.getString("TvTEventTeam1Coordinates", "0,0,0").split(",");
                    if (tvtNpcCoords.length < 3)
                    {
                        TVT_EVENT_ENABLED = false;
                        LOGGER.warning("TvTEventEngine[Config.load()]: invalid config property -> TvTEventTeam1Coordinates");
                    }
                    else
                    {
                        TVT_EVENT_TEAM_1_COORDINATES[0] = Integer.parseInt(tvtNpcCoords[0]);
                        TVT_EVENT_TEAM_1_COORDINATES[1] = Integer.parseInt(tvtNpcCoords[1]);
                        TVT_EVENT_TEAM_1_COORDINATES[2] = Integer.parseInt(tvtNpcCoords[2]);
                        TVT_EVENT_TEAM_2_NAME = TeamVersusTeam.getString("TvTEventTeam2Name", "Team2");
                        tvtNpcCoords = TeamVersusTeam.getString("TvTEventTeam2Coordinates", "0,0,0").split(",");
                        if (tvtNpcCoords.length < 3)
                        {
                            TVT_EVENT_ENABLED = false;
                            LOGGER.warning("TvTEventEngine[Config.load()]: invalid config property -> TvTEventTeam2Coordinates");
                        }
                        else
                        {
                            TVT_EVENT_TEAM_2_COORDINATES[0] = Integer.parseInt(tvtNpcCoords[0]);
                            TVT_EVENT_TEAM_2_COORDINATES[1] = Integer.parseInt(tvtNpcCoords[1]);
                            TVT_EVENT_TEAM_2_COORDINATES[2] = Integer.parseInt(tvtNpcCoords[2]);
                            tvtNpcCoords = TeamVersusTeam.getString("TvTEventParticipationFee", "0,0").split(",");
                            try
                            {
                                TVT_EVENT_PARTICIPATION_FEE[0] = Integer.parseInt(tvtNpcCoords[0]);
                                TVT_EVENT_PARTICIPATION_FEE[1] = Integer.parseInt(tvtNpcCoords[1]);
                            }
                            catch (NumberFormatException nfe)
                            {
                                if (tvtNpcCoords.length > 0)
                                {
                                    LOGGER.warning("TvTEventEngine[Config.load()]: invalid config property -> TvTEventParticipationFee");
                                }
                            }
                            tvtNpcCoords = TeamVersusTeam.getString("TvTEventReward", "57,100000").split(";");
                            for (String reward : tvtNpcCoords)
                            {
                                final String[] rewardSplit = reward.split(",");
                                if (rewardSplit.length != 2)
                                {
                                    LOGGER.warning("TvTEventEngine[Config.load()]: invalid config property -> TvTEventReward \"" + reward + "\"");
                                }
                                else
                                {
                                    try
                                    {
                                        TVT_EVENT_REWARDS.add(new int[]
                                        {
                                            Integer.parseInt(rewardSplit[0]),
                                            Integer.parseInt(rewardSplit[1])
                                        });
                                    }
                                    catch (NumberFormatException nfe)
                                    {
                                        if (!reward.isEmpty())
                                        {
                                            LOGGER.warning("TvTEventEngine[Config.load()]: invalid config property -> TvTEventReward \"" + reward + "\"");
                                        }
                                    }
                                }
                            }
                           
                            TVT_EVENT_TARGET_TEAM_MEMBERS_ALLOWED = TeamVersusTeam.getBoolean("TvTEventTargetTeamMembersAllowed", true);
                            TVT_EVENT_SCROLL_ALLOWED = TeamVersusTeam.getBoolean("TvTEventScrollsAllowed", false);
                            TVT_EVENT_POTIONS_ALLOWED = TeamVersusTeam.getBoolean("TvTEventPotionsAllowed", false);
                            TVT_EVENT_SUMMON_BY_ITEM_ALLOWED = TeamVersusTeam.getBoolean("TvTEventSummonByItemAllowed", false);
                            TVT_REWARD_TEAM_TIE = TeamVersusTeam.getBoolean("TvTRewardTeamTie", false);
                            tvtNpcCoords = TeamVersusTeam.getString("TvTDoorsToOpen", "").split(";");
                            for (String door : tvtNpcCoords)
                            {
                                try
                                {
                                    TVT_DOORS_IDS_TO_OPEN.add(Integer.parseInt(door));
                                }
                                catch (NumberFormatException nfe)
                                {
                                    if (!door.isEmpty())
                                    {
                                        LOGGER.warning("TvTEventEngine[Config.load()]: invalid config property -> TvTDoorsToOpen \"" + door + "\"");
                                    }
                                }
                            }
                           
                            tvtNpcCoords = TeamVersusTeam.getString("TvTDoorsToClose", "").split(";");
                            for (String door : tvtNpcCoords)
                            {
                                try
                                {
                                    TVT_DOORS_IDS_TO_CLOSE.add(Integer.parseInt(door));
                                }
                                catch (NumberFormatException nfe)
                                {
                                    if (!door.isEmpty())
                                    {
                                        LOGGER.warning("TvTEventEngine[Config.load()]: invalid config property -> TvTDoorsToClose \"" + door + "\"");
                                    }
                                }
                            }
                           
                            tvtNpcCoords = TeamVersusTeam.getString("TvTEventFighterBuffs", "").split(";");
                            if (!tvtNpcCoords[0].isEmpty())
                            {
                                TVT_EVENT_FIGHTER_BUFFS = new HashMap<>(tvtNpcCoords.length);
                                for (String skill : tvtNpcCoords)
                                {
                                    final String[] skillSplit = skill.split(",");
                                    if (skillSplit.length != 2)
                                    {
                                        LOGGER.warning("TvTEventEngine[Config.load()]: invalid config property -> TvTEventFighterBuffs \"" + skill + "\"");
                                    }
                                    else
                                    {
                                        try
                                        {
                                            TVT_EVENT_FIGHTER_BUFFS.put(Integer.parseInt(skillSplit[0]), Integer.parseInt(skillSplit[1]));
                                        }
                                        catch (NumberFormatException nfe)
                                        {
                                            if (!skill.isEmpty())
                                            {
                                                LOGGER.warning("TvTEventEngine[Config.load()]: invalid config property -> TvTEventFighterBuffs \"" + skill + "\"");
                                            }
                                        }
                                    }
                                }
                            }
                           
                            tvtNpcCoords = TeamVersusTeam.getString("TvTEventMageBuffs", "").split(";");
                            if (!tvtNpcCoords[0].isEmpty())
                            {
                                TVT_EVENT_MAGE_BUFFS = new HashMap<>(tvtNpcCoords.length);
                                for (String skill : tvtNpcCoords)
                                {
                                    final String[] skillSplit = skill.split(",");
                                    if (skillSplit.length != 2)
                                    {
                                        LOGGER.warning("TvTEventEngine[Config.load()]: invalid config property -> TvTEventMageBuffs \"" + skill + "\"");
                                    }
                                    else
                                    {
                                        try
                                        {
                                            TVT_EVENT_MAGE_BUFFS.put(Integer.parseInt(skillSplit[0]), Integer.parseInt(skillSplit[1]));
                                        }
                                        catch (NumberFormatException nfe)
                                        {
                                            if (!skill.isEmpty())
                                            {
                                                LOGGER.warning("TvTEventEngine[Config.load()]: invalid config property -> TvTEventMageBuffs \"" + skill + "\"");
                                            }
                                        }
                                    }
                                }
                            }
                        }
                    }
                }
            }
           
            // Load WarehouseSorting config file (if exists)
            final PropertiesParser WarehouseSorting = new PropertiesParser(CUSTOM_WAREHOUSE_SORTING_CONFIG_FILE);
           
            ENABLE_WAREHOUSESORTING_CLAN = WarehouseSorting.getBoolean("EnableWarehouseSortingClan", false);
            ENABLE_WAREHOUSESORTING_PRIVATE = WarehouseSorting.getBoolean("EnableWarehouseSortingPrivate", false);
           
            // Load Wedding config file (if exists)
            final PropertiesParser Wedding = new PropertiesParser(CUSTOM_WEDDING_CONFIG_FILE);
           
            ALLOW_WEDDING = Wedding.getBoolean("AllowWedding", false);
            WEDDING_PRICE = Wedding.getInt("WeddingPrice", 250000000);
            WEDDING_PUNISH_INFIDELITY = Wedding.getBoolean("WeddingPunishInfidelity", true);
            WEDDING_TELEPORT = Wedding.getBoolean("WeddingTeleport", true);
            WEDDING_TELEPORT_PRICE = Wedding.getInt("WeddingTeleportPrice", 50000);
            WEDDING_TELEPORT_DURATION = Wedding.getInt("WeddingTeleportDuration", 60);
            WEDDING_SAMESEX = Wedding.getBoolean("WeddingAllowSameSex", false);
            WEDDING_FORMALWEAR = Wedding.getBoolean("WeddingFormalWear", true);
            WEDDING_DIVORCE_COSTS = Wedding.getInt("WeddingDivorceCosts", 20);
           
            // Load VoteReward config file (if exists)
            final PropertiesParser VoteReward = new PropertiesParser(CUSTOM_VOTE_REWARD_CONFIG_FILE);
           
            ALLOW_NETWORK_VOTE_REWARD = VoteReward.getBoolean("AllowNetworkVoteReward", false);
            NETWORK_SERVER_LINK = VoteReward.getString("NetworkServerLink", "");
            NETWORK_VOTES_DIFFERENCE = VoteReward.getInt("NetworkVotesDifference", 5);
            NETWORK_REWARD_CHECK_TIME = VoteReward.getInt("NetworkRewardCheckTime", 5);
            String NETWORK_SMALL_REWARD_VALUE = VoteReward.getString("NetworkReward", "57,100000000;");
            String[] NETWORK_small_reward_splitted_1 = NETWORK_SMALL_REWARD_VALUE.split(";");
            for (String i : NETWORK_small_reward_splitted_1)
            {
                String[] NETWORK_small_reward_splitted_2 = i.split(",");
                NETWORK_REWARD.put(Integer.parseInt(NETWORK_small_reward_splitted_2[0]), Integer.parseInt(NETWORK_small_reward_splitted_2[1]));
            }
            NETWORK_DUALBOXES_ALLOWED = VoteReward.getInt("NetworkDualboxesAllowed", 1);
            ALLOW_NETWORK_GAME_SERVER_REPORT = VoteReward.getBoolean("AllowNetworkGameServerReport", false);
            ALLOW_TOPZONE_VOTE_REWARD = VoteReward.getBoolean("AllowTopzoneVoteReward", false);
            TOPZONE_SERVER_LINK = VoteReward.getString("TopzoneServerLink", "");
            TOPZONE_VOTES_DIFFERENCE = VoteReward.getInt("TopzoneVotesDifference", 5);
            TOPZONE_REWARD_CHECK_TIME = VoteReward.getInt("TopzoneRewardCheckTime", 5);
            String TOPZONE_SMALL_REWARD_VALUE = VoteReward.getString("TopzoneReward", "57,100000000;");
            String[] topzone_small_reward_splitted_1 = TOPZONE_SMALL_REWARD_VALUE.split(";");
            for (String i : topzone_small_reward_splitted_1)
            {
                String[] topzone_small_reward_splitted_2 = i.split(",");
                TOPZONE_REWARD.put(Integer.parseInt(topzone_small_reward_splitted_2[0]), Integer.parseInt(topzone_small_reward_splitted_2[1]));
            }
            TOPZONE_DUALBOXES_ALLOWED = VoteReward.getInt("TopzoneDualboxesAllowed", 1);
            ALLOW_TOPZONE_GAME_SERVER_REPORT = VoteReward.getBoolean("AllowTopzoneGameServerReport", false);
            ALLOW_HOPZONE_VOTE_REWARD = VoteReward.getBoolean("AllowHopzoneVoteReward", false);
            HOPZONE_SERVER_LINK = VoteReward.getString("HopzoneServerLink", "");
            HOPZONE_VOTES_DIFFERENCE = VoteReward.getInt("HopzoneVotesDifference", 5);
            HOPZONE_REWARD_CHECK_TIME = VoteReward.getInt("HopzoneRewardCheckTime", 5);
            String HOPZONE_SMALL_REWARD_VALUE = VoteReward.getString("HopzoneReward", "57,100000000;");
            String[] hopzone_small_reward_splitted_1 = HOPZONE_SMALL_REWARD_VALUE.split(";");
            for (String i : hopzone_small_reward_splitted_1)
            {
                String[] hopzone_small_reward_splitted_2 = i.split(",");
                HOPZONE_REWARD.put(Integer.parseInt(hopzone_small_reward_splitted_2[0]), Integer.parseInt(hopzone_small_reward_splitted_2[1]));
            }
            HOPZONE_DUALBOXES_ALLOWED = VoteReward.getInt("HopzoneDualboxesAllowed", 1);
            ALLOW_HOPZONE_GAME_SERVER_REPORT = VoteReward.getBoolean("AllowHopzoneGameServerReport", false);
           
            // Load WalkerBotProtection config file (if exists)
            final PropertiesParser WalkerBotProtection = new PropertiesParser(CUSTOM_WALKER_BOT_PROTECTION_CONFIG_FILE);
           
            L2WALKER_PROTECTION = WalkerBotProtection.getBoolean("L2WalkerProtection", false);
        }
        else if (Server.serverMode == Server.MODE_LOGINSERVER)
        {
            final PropertiesParser ServerSettings = new PropertiesParser(LOGIN_CONFIG_FILE);
           
            GAME_SERVER_LOGIN_HOST = ServerSettings.getString("LoginHostname", "127.0.0.1");
            GAME_SERVER_LOGIN_PORT = ServerSettings.getInt("LoginPort", 9013);
           
            LOGIN_BIND_ADDRESS = ServerSettings.getString("LoginserverHostname", "0.0.0.0");
            PORT_LOGIN = ServerSettings.getInt("LoginserverPort", 2106);
           
            try
            {
                DATAPACK_ROOT = new File(ServerSettings.getString("DatapackRoot", ".").replaceAll("\\\\", "/")).getCanonicalFile();
            }
            catch (IOException e)
            {
                LOGGER.log(Level.WARNING, "Error setting datapack root!", e);
                DATAPACK_ROOT = new File(".");
            }
           
            ACCEPT_NEW_GAMESERVER = ServerSettings.getBoolean("AcceptNewGameServer", true);
           
            LOGIN_TRY_BEFORE_BAN = ServerSettings.getInt("LoginTryBeforeBan", 5);
            LOGIN_BLOCK_AFTER_BAN = ServerSettings.getInt("LoginBlockAfterBan", 900);
           
            LOGIN_SERVER_SCHEDULE_RESTART = ServerSettings.getBoolean("LoginRestartSchedule", false);
            LOGIN_SERVER_SCHEDULE_RESTART_TIME = ServerSettings.getLong("LoginRestartTime", 24);
           
            DATABASE_DRIVER = ServerSettings.getString("Driver", "org.mariadb.jdbc.Driver");
            DATABASE_URL = ServerSettings.getString("URL", "jdbc:mariadb://localhost/login?useUnicode=true&characterEncoding=utf-8");
            DATABASE_LOGIN = ServerSettings.getString("Login", "user");
            DATABASE_PASSWORD = ServerSettings.getString("Password", "user");
            DATABASE_MAX_CONNECTIONS = ServerSettings.getInt("MaximumDbConnections", 10);
            DATABASE_MAX_IDLE_TIME = ServerSettings.getInt("MaximumDbIdleTime", 0);
           
            BACKUP_DATABASE = ServerSettings.getBoolean("BackupDatabase", false);
            MYSQL_BIN_PATH = ServerSettings.getString("MySqlBinLocation", "");
            BACKUP_PATH = ServerSettings.getString("BackupPath", "../backup/");
            BACKUP_DAYS = ServerSettings.getInt("BackupDays", 30);
           
            SHOW_LICENCE = ServerSettings.getBoolean("ShowLicence", true);
           
            AUTO_CREATE_ACCOUNTS = ServerSettings.getBoolean("AutoCreateAccounts", true);
           
            FLOOD_PROTECTION = ServerSettings.getBoolean("EnableFloodProtection", true);
            FAST_CONNECTION_LIMIT = ServerSettings.getInt("FastConnectionLimit", 15);
            NORMAL_CONNECTION_TIME = ServerSettings.getInt("NormalConnectionTime", 700);
            FAST_CONNECTION_TIME = ServerSettings.getInt("FastConnectionTime", 350);
            MAX_CONNECTION_PER_IP = ServerSettings.getInt("MaxConnectionPerIP", 50);
        }
        else
        {
            LOGGER.severe("Could not Load Config: server mode was not set!");
        }
    }
   
    /**
     * Save hexadecimal ID of the server in the config file.<br>
     * Check {@link #HEXID_FILE}.
     * @param serverId the ID of the server whose hexId to save
     * @param hexId the hexadecimal ID to store
     */
    public static void saveHexid(int serverId, String hexId)
    {
        saveHexid(serverId, hexId, HEXID_FILE);
    }
   
    /**
     * Save hexadecimal ID of the server in the config file.
     * @param serverId the ID of the server whose hexId to save
     * @param hexId the hexadecimal ID to store
     * @param fileName name of the config file
     */
    public static void saveHexid(int serverId, String hexId, String fileName)
    {
        try
        {
            final Properties hexSetting = new Properties();
            final File file = new File(fileName);
            // Create a new empty file only if it doesn't exist
            if (!file.exists())
            {
                try (OutputStream out = new FileOutputStream(file))
                {
                    hexSetting.setProperty("ServerID", String.valueOf(serverId));
                    hexSetting.setProperty("HexID", hexId);
                    hexSetting.store(out, "The HexId to Auth into LoginServer");
                    LOGGER.log(Level.INFO, "Gameserver: Generated new HexID file for server id " + serverId + ".");
                }
            }
        }
        catch (Exception e)
        {
            LOGGER.warning("Failed to save hex id to " + fileName + " File.");
            LOGGER.warning("Config: " + e.getMessage());
        }
    }
   
    /**
     * Loads flood protector configurations.
     * @param properties the properties object containing the actual values of the flood protector configs
     */
    private static void loadFloodProtectorConfigs(PropertiesParser properties)
    {
        loadFloodProtectorConfig(properties, FLOOD_PROTECTOR_USE_ITEM, "UseItem", 4);
        loadFloodProtectorConfig(properties, FLOOD_PROTECTOR_ROLL_DICE, "RollDice", 42);
        loadFloodProtectorConfig(properties, FLOOD_PROTECTOR_FIREWORK, "Firework", 42);
        loadFloodProtectorConfig(properties, FLOOD_PROTECTOR_ITEM_PET_SUMMON, "ItemPetSummon", 16);
        loadFloodProtectorConfig(properties, FLOOD_PROTECTOR_HERO_VOICE, "HeroVoice", 100);
        loadFloodProtectorConfig(properties, FLOOD_PROTECTOR_GLOBAL_CHAT, "GlobalChat", 5);
        loadFloodProtectorConfig(properties, FLOOD_PROTECTOR_SUBCLASS, "Subclass", 20);
        loadFloodProtectorConfig(properties, FLOOD_PROTECTOR_DROP_ITEM, "DropItem", 10);
        loadFloodProtectorConfig(properties, FLOOD_PROTECTOR_SERVER_BYPASS, "ServerBypass", 5);
        loadFloodProtectorConfig(properties, FLOOD_PROTECTOR_MULTISELL, "MultiSell", 1);
        loadFloodProtectorConfig(properties, FLOOD_PROTECTOR_TRANSACTION, "Transaction", 10);
        loadFloodProtectorConfig(properties, FLOOD_PROTECTOR_MANUFACTURE, "Manufacture", 3);
        loadFloodProtectorConfig(properties, FLOOD_PROTECTOR_MANOR, "Manor", 30);
        loadFloodProtectorConfig(properties, FLOOD_PROTECTOR_SENDMAIL, "SendMail", 100);
        loadFloodProtectorConfig(properties, FLOOD_PROTECTOR_CHARACTER_SELECT, "CharacterSelect", 30);
        loadFloodProtectorConfig(properties, FLOOD_PROTECTOR_ITEM_AUCTION, "ItemAuction", 9);
    }
   
    /**
     * Loads single flood protector configuration.
     * @param properties config file reader
     * @param config flood protector configuration instance
     * @param configString flood protector configuration string that determines for which flood protector configuration should be read
     * @param defaultInterval default flood protector interval
     */
    private static void loadFloodProtectorConfig(PropertiesParser properties, FloodProtectorConfig config, String configString, int defaultInterval)
    {
        config.FLOOD_PROTECTION_INTERVAL = properties.getInt("FloodProtector" + configString + "Interval", defaultInterval);
        config.LOG_FLOODING = properties.getBoolean("FloodProtector" + configString + "LogFlooding", false);
        config.PUNISHMENT_LIMIT = properties.getInt("FloodProtector" + configString + "PunishmentLimit", 0);
        config.PUNISHMENT_TYPE = properties.getString("FloodProtector" + configString + "PunishmentType", "none");
        config.PUNISHMENT_TIME = properties.getInt("FloodProtector" + configString + "PunishmentTime", 0) * 60000;
    }
   
    public static int getServerTypeId(String[] serverTypes)
    {
        int serverType = 0;
        for (String cType : serverTypes)
        {
            switch (cType.trim().toLowerCase())
            {
                case "normal":
                {
                    serverType |= 0x01;
                    break;
                }
                case "relax":
                {
                    serverType |= 0x02;
                    break;
                }
                case "test":
                {
                    serverType |= 0x04;
                    break;
                }
                case "nolabel":
                {
                    serverType |= 0x08;
                    break;
                }
                case "restricted":
                {
                    serverType |= 0x10;
                    break;
                }
                case "event":
                {
                    serverType |= 0x20;
                    break;
                }
                case "free":
                {
                    serverType |= 0x40;
                    break;
                }
                default:
                {
                    break;
                }
            }
        }
        return serverType;
    }
   
    public static final class ClassMasterSettings
    {
        private final Map<Integer, List<ItemHolder>> _claimItems = new HashMap<>(3);
        private final Map<Integer, List<ItemHolder>> _rewardItems = new HashMap<>(3);
        private final Map<Integer, Boolean> _allowedClassChange = new HashMap<>(3);
       
        public ClassMasterSettings(String configLine)
        {
            parseConfigLine(configLine.trim());
        }
       
        private void parseConfigLine(String configLine)
        {
            if (configLine.isEmpty())
            {
                return;
            }
           
            final StringTokenizer st = new StringTokenizer(configLine, ";");
           
            while (st.hasMoreTokens())
            {
                // get allowed class change
                final int job = Integer.parseInt(st.nextToken());
               
                _allowedClassChange.put(job, true);
               
                final List<ItemHolder> requiredItems = new ArrayList<>();
                // parse items needed for class change
                if (st.hasMoreTokens())
                {
                    final StringTokenizer st2 = new StringTokenizer(st.nextToken(), "[],");
                   
                    while (st2.hasMoreTokens())
                    {
                        final StringTokenizer st3 = new StringTokenizer(st2.nextToken(), "()");
                        final int itemId = Integer.parseInt(st3.nextToken());
                        final int quantity = Integer.parseInt(st3.nextToken());
                        requiredItems.add(new ItemHolder(itemId, quantity));
                    }
                }
               
                _claimItems.put(job, requiredItems);
               
                final List<ItemHolder> rewardItems = new ArrayList<>();
                // parse gifts after class change
                if (st.hasMoreTokens())
                {
                    final StringTokenizer st2 = new StringTokenizer(st.nextToken(), "[],");
                   
                    while (st2.hasMoreTokens())
                    {
                        final StringTokenizer st3 = new StringTokenizer(st2.nextToken(), "()");
                        final int itemId = Integer.parseInt(st3.nextToken());
                        final int quantity = Integer.parseInt(st3.nextToken());
                        rewardItems.add(new ItemHolder(itemId, quantity));
                    }
                }
               
                _rewardItems.put(job, rewardItems);
            }
        }
       
        public boolean isAllowed(int job)
        {
            return (_allowedClassChange != null) && _allowedClassChange.containsKey(job) && _allowedClassChange.get(job);
        }
       
        public List<ItemHolder> getRewardItems(int job)
        {
            return _rewardItems.get(job);
        }
       
        public List<ItemHolder> getRequireItems(int job)
        {
            return _claimItems.get(job);
        }
    }
   
    /**
     * @param line the string line to parse
     * @return a parsed float map
     */
    private static Map<Integer, Float> parseConfigLine(String line)
    {
        final String[] propertySplit = line.split(",");
        final Map<Integer, Float> ret = new HashMap<>(propertySplit.length);
        int i = 0;
        for (String value : propertySplit)
        {
            ret.put(i++, Float.parseFloat(value));
        }
        return ret;
    }
   
    /**
     * Parse a config value from its string representation to a two-dimensional int array.<br>
     * The format of the value to be parsed should be as follows: "item1Id,item1Amount;item2Id,item2Amount;...itemNId,itemNAmount".
     * @param line the value of the parameter to parse
     * @return the parsed list or {@code null} if nothing was parsed
     */
    private static int[][] parseItemsList(String line)
    {
        final String[] propertySplit = line.split(";");
        if (propertySplit.length == 0)
        {
            // nothing to do here
            return null;
        }
       
        int i = 0;
        String[] valueSplit;
        final int[][] result = new int[propertySplit.length][];
        int[] tmp;
        for (String value : propertySplit)
        {
            valueSplit = value.split(",");
            if (valueSplit.length != 2)
            {
                LOGGER.warning("parseItemsList[Config.load()]: invalid entry -> \"" + valueSplit[0] + "\", should be itemId,itemNumber. Skipping to the next entry in the list.");
                continue;
            }
           
            tmp = new int[2];
            try
            {
                tmp[0] = Integer.parseInt(valueSplit[0]);
            }
            catch (NumberFormatException e)
            {
                LOGGER.warning("parseItemsList[Config.load()]: invalid itemId -> \"" + valueSplit[0] + "\", value must be an integer. Skipping to the next entry in the list.");
                continue;
            }
            try
            {
                tmp[1] = Integer.parseInt(valueSplit[1]);
            }
            catch (NumberFormatException e)
            {
                LOGGER.warning("parseItemsList[Config.load()]: invalid item number -> \"" + valueSplit[1] + "\", value must be an integer. Skipping to the next entry in the list.");
                continue;
            }
            result[i++] = tmp;
        }
        return result;
    }
   
    private static class IPConfigData implements IGameXmlReader
    {
        private static final List<String> _subnets = new ArrayList<>(5);
        private static final List<String> _hosts = new ArrayList<>(5);
       
        public IPConfigData()
        {
            load();
        }
       
        @Override
        public void load()
        {
            final File f = new File(IPCONFIG_FILE);
            if (f.exists())
            {
                LOGGER.info("Network Config: ipconfig.xml exists using manual configuration...");
                parseFile(new File(IPCONFIG_FILE));
            }
            else
            // Auto configuration...
            {
                LOGGER.info("Network Config: ipconfig.xml doesn't exists using automatic configuration...");
                autoIpConfig();
            }
        }
       
        @Override
        public void parseDocument(Document doc, File f)
        {
            NamedNodeMap attrs;
            for (Node n = doc.getFirstChild(); n != null; n = n.getNextSibling())
            {
                if ("gameserver".equalsIgnoreCase(n.getNodeName()))
                {
                    for (Node d = n.getFirstChild(); d != null; d = d.getNextSibling())
                    {
                        if ("define".equalsIgnoreCase(d.getNodeName()))
                        {
                            attrs = d.getAttributes();
                            _subnets.add(attrs.getNamedItem("subnet").getNodeValue());
                            _hosts.add(attrs.getNamedItem("address").getNodeValue());
                           
                            if (_hosts.size() != _subnets.size())
                            {
                                LOGGER.warning("Failed to Load " + IPCONFIG_FILE + " File - subnets does not match server addresses.");
                            }
                        }
                    }
                   
                    final Node att = n.getAttributes().getNamedItem("address");
                    if (att == null)
                    {
                        LOGGER.warning("Failed to load " + IPCONFIG_FILE + " file - default server address is missing.");
                        _hosts.add("127.0.0.1");
                    }
                    else
                    {
                        _hosts.add(att.getNodeValue());
                    }
                    _subnets.add("0.0.0.0/0");
                }
            }
        }
       
        protected void autoIpConfig()
        {
            String externalIp = "127.0.0.1";
            try
            {
                final URL autoIp = new URL("http://ip1.dynupdate.no-ip.com:8245/");
                try (BufferedReader in = new BufferedReader(new InputStreamReader(autoIp.openStream())))
                {
                    externalIp = in.readLine();
                }
            }
            catch (IOException e)
            {
                LOGGER.log(Level.INFO, "Failed to connect to api.externalip.net please check your internet connection using 127.0.0.1!");
                externalIp = "127.0.0.1";
            }
           
            try
            {
                final Enumeration<NetworkInterface> niList = NetworkInterface.getNetworkInterfaces();
               
                while (niList.hasMoreElements())
                {
                    final NetworkInterface ni = niList.nextElement();
                   
                    if (!ni.isUp() || ni.isVirtual())
                    {
                        continue;
                    }
                   
                    if (!ni.isLoopback() && ((ni.getHardwareAddress() == null) || (ni.getHardwareAddress().length != 6)))
                    {
                        continue;
                    }
                   
                    for (InterfaceAddress ia : ni.getInterfaceAddresses())
                    {
                        if (ia.getAddress() instanceof Inet6Address)
                        {
                            continue;
                        }
                       
                        final String hostAddress = ia.getAddress().getHostAddress();
                        final int subnetPrefixLength = ia.getNetworkPrefixLength();
                        final int subnetMaskInt = IntStream.rangeClosed(1, subnetPrefixLength).reduce((r, e) -> (r << 1) + 1).orElse(0) << (32 - subnetPrefixLength);
                        final int hostAddressInt = Arrays.stream(hostAddress.split("\\.")).mapToInt(Integer::parseInt).reduce((r, e) -> (r << 8) + e).orElse(0);
                        final int subnetAddressInt = hostAddressInt & subnetMaskInt;
                        final String subnetAddress = ((subnetAddressInt >> 24) & 0xFF) + "." + ((subnetAddressInt >> 16) & 0xFF) + "." + ((subnetAddressInt >> 8) & 0xFF) + "." + (subnetAddressInt & 0xFF);
                        final String subnet = subnetAddress + '/' + subnetPrefixLength;
                        if (!_subnets.contains(subnet) && !subnet.equals("0.0.0.0/0"))
                        {
                            _subnets.add(subnet);
                            _hosts.add(hostAddress);
                            LOGGER.info("Network Config: Adding new subnet: " + subnet + " address: " + hostAddress);
                        }
                    }
                }
               
                // External host and subnet
                _hosts.add(externalIp);
                _subnets.add("0.0.0.0/0");
                LOGGER.info("Network Config: Adding new subnet: 0.0.0.0/0 address: " + externalIp);
            }
            catch (SocketException e)
            {
                LOGGER.log(Level.INFO, "Network Config: Configuration failed please configure manually using ipconfig.xml", e);
                System.exit(0);
            }
        }
       
        protected List<String> getSubnets()
        {
            if (_subnets.isEmpty())
            {
                return Arrays.asList("0.0.0.0/0");
            }
            return _subnets;
        }
       
        protected List<String> getHosts()
        {
            if (_hosts.isEmpty())
            {
                return Arrays.asList("127.0.0.1");
            }
            return _hosts;
        }
    }
}
 
может нужно указать правильные пути working directory для модулей game и login?
 
может нужно указать правильные пути working directory для модулей game и login?
Батниками грузит нормально. А вот идея не подхватывает, хоть и в продакшен она их билдит.
screen.jpg

Удалил эту дичь с ./log.cfg и закинул log4j2.xml.
Теперь гс вообще ничего не видит.
Код:
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser <init>
WARNING: [GameServer.ini] There was an error loading config reason: \config\GameServer.ini (Системе не удается найти указанный путь)
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [GameServer.ini] missing property for key: GameserverHostname using default value: 0.0.0.0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [GameServer.ini] missing property for key: GameserverPort using default value: 7777
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [GameServer.ini] missing property for key: LoginPort using default value: 9014
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [GameServer.ini] missing property for key: LoginHost using default value: 127.0.0.1
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [GameServer.ini] missing property for key: RequestServerID using default value: 0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [GameServer.ini] missing property for key: AcceptAlternateID using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [GameServer.ini] missing property for key: Driver using default value: org.mariadb.jdbc.Driver
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [GameServer.ini] missing property for key: URL using default value: jdbc:mariadb://localhost/game?useUnicode=true&characterEncoding=utf-8
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [GameServer.ini] missing property for key: Login using default value: user
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [GameServer.ini] missing property for key: Password using default value: user
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [GameServer.ini] missing property for key: MaximumDbConnections using default value: 10
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [GameServer.ini] missing property for key: MaximumDbIdleTime using default value: 0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [GameServer.ini] missing property for key: BackupDatabase using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [GameServer.ini] missing property for key: MySqlBinLocation using default value:
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [GameServer.ini] missing property for key: BackupPath using default value: ../backup/
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [GameServer.ini] missing property for key: BackupDays using default value: 30
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [GameServer.ini] missing property for key: DatapackRoot using default value: .
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [GameServer.ini] missing property for key: CnameTemplate using default value: .*
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [GameServer.ini] missing property for key: PetNameTemplate using default value: .*
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [GameServer.ini] missing property for key: ClanNameTemplate using default value: .*
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [GameServer.ini] missing property for key: CharMaxNumber using default value: 7
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [GameServer.ini] missing property for key: MaximumOnlineUsers using default value: 2000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [GameServer.ini] missing property for key: AllowedProtocolRevisions using default value: 267;268;271;273
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [GameServer.ini] missing property for key: ServerListType using default value: free
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [GameServer.ini] missing property for key: ServerListAge using default value: 0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [GameServer.ini] missing property for key: ServerListBrackets using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [GameServer.ini] missing property for key: ScheduledThreadPoolCount using default value: -1
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [GameServer.ini] missing property for key: ThreadsPerScheduledThreadPool using default value: 4
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [GameServer.ini] missing property for key: InstantThreadPoolCount using default value: -1
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [GameServer.ini] missing property for key: ThreadsPerInstantThreadPool using default value: 2
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [GameServer.ini] missing property for key: UrgentPacketThreadCoreSize using default value: 2
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [GameServer.ini] missing property for key: DeadLockDetector using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [GameServer.ini] missing property for key: DeadLockCheckInterval using default value: 20
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [GameServer.ini] missing property for key: RestartOnDeadlock using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [GameServer.ini] missing property for key: ServerRestartScheduleEnabled using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [GameServer.ini] missing property for key: ServerRestartScheduleMessage using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [GameServer.ini] missing property for key: ServerRestartScheduleCountdown using default value: 600
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [GameServer.ini] missing property for key: ServerRestartSchedule using default value: 08:00
мая 21, 2019 2:34:27 ПП l2j.Config$IPConfigData load
INFO: Network Config: ipconfig.xml doesn't exists using automatic configuration...
мая 21, 2019 2:34:27 ПП l2j.Config$IPConfigData autoIpConfig
INFO: Network Config: Adding new subnet: 127.0.0.0/8 address: 127.0.0.1
мая 21, 2019 2:34:27 ПП l2j.Config$IPConfigData autoIpConfig
INFO: Network Config: Adding new subnet: 192.168.1.0/24 address: 192.168.1.67
мая 21, 2019 2:34:27 ПП l2j.Config$IPConfigData autoIpConfig
INFO: Network Config: Adding new subnet: 0.0.0.0/0 address: 128.70.109.39
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser <init>
WARNING: [Feature.ini] There was an error loading config reason: \config\Feature.ini (Системе не удается найти указанный путь)
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: ClanHallTeleportFunctionFeeRatio using default value: 604800000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallTeleportFunctionFeeLvl1 using default value: 7000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallTeleportFunctionFeeLvl2 using default value: 14000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: ClanHallSupportFunctionFeeRatio using default value: 86400000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallSupportFeeLvl1 using default value: 2500
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallSupportFeeLvl2 using default value: 5000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallSupportFeeLvl3 using default value: 7000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallSupportFeeLvl4 using default value: 11000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallSupportFeeLvl5 using default value: 21000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallSupportFeeLvl6 using default value: 36000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallSupportFeeLvl7 using default value: 37000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallSupportFeeLvl8 using default value: 52000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: ClanHallMpRegenerationFunctionFeeRatio using default value: 86400000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallMpRegenerationFeeLvl1 using default value: 2000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallMpRegenerationFeeLvl2 using default value: 3750
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallMpRegenerationFeeLvl3 using default value: 6500
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallMpRegenerationFeeLvl4 using default value: 13750
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallMpRegenerationFeeLvl5 using default value: 20000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: ClanHallHpRegenerationFunctionFeeRatio using default value: 86400000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallHpRegenerationFeeLvl1 using default value: 700
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallHpRegenerationFeeLvl2 using default value: 800
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallHpRegenerationFeeLvl3 using default value: 1000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallHpRegenerationFeeLvl4 using default value: 1166
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallHpRegenerationFeeLvl5 using default value: 1500
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallHpRegenerationFeeLvl6 using default value: 1750
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallHpRegenerationFeeLvl7 using default value: 2000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallHpRegenerationFeeLvl8 using default value: 2250
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallHpRegenerationFeeLvl9 using default value: 2500
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallHpRegenerationFeeLvl10 using default value: 3250
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallHpRegenerationFeeLvl11 using default value: 3270
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallHpRegenerationFeeLvl12 using default value: 4250
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallHpRegenerationFeeLvl13 using default value: 5166
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: ClanHallExpRegenerationFunctionFeeRatio using default value: 86400000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallExpRegenerationFeeLvl1 using default value: 3000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallExpRegenerationFeeLvl2 using default value: 6000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallExpRegenerationFeeLvl3 using default value: 9000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallExpRegenerationFeeLvl4 using default value: 15000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallExpRegenerationFeeLvl5 using default value: 21000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallExpRegenerationFeeLvl6 using default value: 23330
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallExpRegenerationFeeLvl7 using default value: 30000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: ClanHallItemCreationFunctionFeeRatio using default value: 86400000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallItemCreationFunctionFeeLvl1 using default value: 30000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallItemCreationFunctionFeeLvl2 using default value: 70000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallItemCreationFunctionFeeLvl3 using default value: 140000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: ClanHallCurtainFunctionFeeRatio using default value: 604800000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallCurtainFunctionFeeLvl1 using default value: 2000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallCurtainFunctionFeeLvl2 using default value: 2500
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: ClanHallFrontPlatformFunctionFeeRatio using default value: 259200000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallFrontPlatformFunctionFeeLvl1 using default value: 1300
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanHallFrontPlatformFunctionFeeLvl2 using default value: 4000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Feature.ini] missing property for key: AltClanHallMpBuffFree using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Feature.ini] missing property for key: SiegeHourList using default value:
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: CastleTeleportFunctionFeeRatio using default value: 604800000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: CastleTeleportFunctionFeeLvl1 using default value: 1000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: CastleTeleportFunctionFeeLvl2 using default value: 10000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: CastleSupportFunctionFeeRatio using default value: 604800000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: CastleSupportFeeLvl1 using default value: 49000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: CastleSupportFeeLvl2 using default value: 120000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: CastleMpRegenerationFunctionFeeRatio using default value: 604800000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: CastleMpRegenerationFeeLvl1 using default value: 45000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: CastleMpRegenerationFeeLvl2 using default value: 65000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: CastleHpRegenerationFunctionFeeRatio using default value: 604800000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: CastleHpRegenerationFeeLvl1 using default value: 12000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: CastleHpRegenerationFeeLvl2 using default value: 20000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: CastleExpRegenerationFunctionFeeRatio using default value: 604800000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: CastleExpRegenerationFeeLvl1 using default value: 63000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: CastleExpRegenerationFeeLvl2 using default value: 70000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: OuterDoorUpgradePriceLvl2 using default value: 3000000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: OuterDoorUpgradePriceLvl3 using default value: 4000000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: OuterDoorUpgradePriceLvl5 using default value: 5000000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: InnerDoorUpgradePriceLvl2 using default value: 750000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: InnerDoorUpgradePriceLvl3 using default value: 900000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: InnerDoorUpgradePriceLvl5 using default value: 1000000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: WallUpgradePriceLvl2 using default value: 1600000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: WallUpgradePriceLvl3 using default value: 1800000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: WallUpgradePriceLvl5 using default value: 2000000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: TrapUpgradePriceLvl1 using default value: 3000000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: TrapUpgradePriceLvl2 using default value: 4000000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: TrapUpgradePriceLvl3 using default value: 5000000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: TrapUpgradePriceLvl4 using default value: 6000000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: FortressTeleportFunctionFeeRatio using default value: 604800000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: FortressTeleportFunctionFeeLvl1 using default value: 1000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: FortressTeleportFunctionFeeLvl2 using default value: 10000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: FortressSupportFunctionFeeRatio using default value: 86400000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: FortressSupportFeeLvl1 using default value: 7000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: FortressSupportFeeLvl2 using default value: 17000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: FortressMpRegenerationFunctionFeeRatio using default value: 86400000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: FortressMpRegenerationFeeLvl1 using default value: 6500
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: FortressMpRegenerationFeeLvl2 using default value: 9300
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: FortressHpRegenerationFunctionFeeRatio using default value: 86400000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: FortressHpRegenerationFeeLvl1 using default value: 2000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: FortressHpRegenerationFeeLvl2 using default value: 3500
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: FortressExpRegenerationFunctionFeeRatio using default value: 86400000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: FortressExpRegenerationFeeLvl1 using default value: 9000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: FortressExpRegenerationFeeLvl2 using default value: 10000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: FortressPeriodicUpdateFrequency using default value: 360
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: FortressBloodOathCount using default value: 1
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: FortressMaxSupplyLevel using default value: 6
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: FortressFeeForCastle using default value: 25000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: FortressMaximumOwnTime using default value: 168
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Feature.ini] missing property for key: AltCastleForDawn using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Feature.ini] missing property for key: AltCastleForDusk using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Feature.ini] missing property for key: AltRequireClanCastle using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: AltFestivalMinPlayer using default value: 5
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: AltMaxPlayerContrib using default value: 1000000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: AltFestivalManagerStart using default value: 120000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: AltFestivalLength using default value: 1080000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: AltFestivalCycleLength using default value: 2280000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: AltFestivalFirstSpawn using default value: 120000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: AltFestivalFirstSwarm using default value: 300000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: AltFestivalSecondSpawn using default value: 540000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: AltFestivalSecondSwarm using default value: 720000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Feature.ini] missing property for key: AltFestivalChestSpawn using default value: 900000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Feature.ini] missing property for key: AltDawnGatesPdefMult using default value: 1.1
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Feature.ini] missing property for key: AltDuskGatesPdefMult using default value: 0.8
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Feature.ini] missing property for key: AltDawnGatesMdefMult using default value: 1.1
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Feature.ini] missing property for key: AltDuskGatesMdefMult using default value: 0.8
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Feature.ini] missing property for key: StrictSevenSigns using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Feature.ini] missing property for key: AltSevenSignsLazyUpdate using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: SevenSignsDawnTicketQuantity using default value: 300
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: SevenSignsDawnTicketPrice using default value: 1000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: SevenSignsDawnTicketBundle using default value: 10
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: SevenSignsManorsAgreementId using default value: 6388
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: SevenSignsJoinDawnFee using default value: 50000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: TakeFortPoints using default value: 200
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: LooseFortPoints using default value: 0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: TakeCastlePoints using default value: 1500
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: LooseCastlePoints using default value: 3000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: CastleDefendedPoints using default value: 750
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: FestivalOfDarknessWin using default value: 200
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: HeroPoints using default value: 1000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: CreateRoyalGuardCost using default value: 5000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: CreateKnightUnitCost using default value: 10000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ReinforceKnightUnitCost using default value: 5000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: KillBallistaPoints using default value: 30
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: BloodAlliancePoints using default value: 500
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: BloodOathPoints using default value: 200
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: KnightsEpaulettePoints using default value: 20
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ReputationScorePerKill using default value: 1
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: CompleteAcademyMinPoints using default value: 190
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: CompleteAcademyMaxPoints using default value: 650
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: 1stRaidRankingPoints using default value: 1250
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: 2ndRaidRankingPoints using default value: 900
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: 3rdRaidRankingPoints using default value: 700
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: 4thRaidRankingPoints using default value: 600
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: 5thRaidRankingPoints using default value: 450
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: 6thRaidRankingPoints using default value: 350
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: 7thRaidRankingPoints using default value: 300
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: 8thRaidRankingPoints using default value: 200
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: 9thRaidRankingPoints using default value: 150
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: 10thRaidRankingPoints using default value: 100
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: UpTo50thRaidRankingPoints using default value: 25
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: UpTo100thRaidRankingPoints using default value: 12
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanLevel6Cost using default value: 5000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanLevel7Cost using default value: 10000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanLevel8Cost using default value: 20000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanLevel9Cost using default value: 40000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanLevel10Cost using default value: 40000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanLevel11Cost using default value: 75000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanLevel6Requirement using default value: 30
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanLevel7Requirement using default value: 50
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanLevel8Requirement using default value: 80
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanLevel9Requirement using default value: 120
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanLevel10Requirement using default value: 140
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Feature.ini] missing property for key: ClanLevel11Requirement using default value: 170
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Feature.ini] missing property for key: AllowRideWyvernAlways using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Feature.ini] missing property for key: AllowRideWyvernDuringSiege using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Feature.ini] missing property for key: AllowRideMountsDuringSiege using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser <init>
WARNING: [Character.ini] There was an error loading config reason: \config\Character.ini (Системе не удается найти указанный путь)
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: Delevel using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: DecreaseSkillOnDelevel using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: AltWeightLimit using default value: 1.0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: RunSpeedBoost using default value: 0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: DeathPenaltyChance using default value: 20
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: RespawnRestoreCP using default value: 0.0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: RespawnRestoreHP using default value: 65.0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: RespawnRestoreMP using default value: 0.0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: HpRegenMultiplier using default value: 100.0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: MpRegenMultiplier using default value: 100.0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: CpRegenMultiplier using default value: 100.0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: EnableModifySkillDuration using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: EnableModifySkillReuse using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AutoLearnSkills using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AutoLearnForgottenScrollSkills using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AutoLootHerbs using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getByte
WARNING: [Character.ini] missing property for key: MaxBuffAmount using default value: 20
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getByte
WARNING: [Character.ini] missing property for key: MaxTriggeredBuffAmount using default value: 12
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getByte
WARNING: [Character.ini] missing property for key: MaxDanceAmount using default value: 12
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: DanceCancelBuff using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: DanceConsumeAdditionalMP using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltStoreDances using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AutoLearnDivineInspiration using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Character.ini] missing property for key: AltGameCancelByHit using default value: Cast
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Character.ini] missing property for key: AltGameCancelByHit using default value: Cast
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Character.ini] missing property for key: AltGameCancelByHit using default value: Cast
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: MagicFailures using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: PlayerFakeDeathUpProtection using default value: 0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: StoreSkillCooltime using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: SubclassStoreSkillCooltime using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: SummonStoreSkillCooltime using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltShieldBlocks using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: AltPerfectShieldBlockRate using default value: 10
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Character.ini] missing property for key: EffectTickRatio using default value: 666
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AllowClassMasters using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AllowEntireTree using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AlternateClassMaster using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: LifeCrystalNeeded using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: EnchantSkillSpBookNeeded using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: DivineInspirationSpBookNeeded using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltGameSkillLearn using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltSubClassWithoutQuests using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltSubclassEverywhere using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: RestoreServitorOnReconnect using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: RestorePetOnReconnect using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltTransformationWithoutQuest using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: FeeDeleteTransferSkills using default value: 10000000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: FeeDeleteSubClassSkills using default value: 10000000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: EnableVitality using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: RecoverVitalityOnReconnect using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: StartingVitalityPoints using default value: 20000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: RaidbossUseVitality using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: MaxExpBonus using default value: 3.5
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: MaxSpBonus using default value: 3.5
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaxRunSpeed using default value: 250
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaxPAtk using default value: 999999
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaxMAtk using default value: 999999
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaxPCritRate using default value: 500
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaxMCritRate using default value: 200
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaxPAtkSpeed using default value: 1500
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaxMAtkSpeed using default value: 1999
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaxEvasion using default value: 250
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MinAbnormalStateSuccessRate using default value: 10
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaxAbnormalStateSuccessRate using default value: 90
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Character.ini] missing property for key: MaxSp using default value: 50000000000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Character.ini] missing property for key: MaxSp using default value: 50000000000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getByte
WARNING: [Character.ini] missing property for key: MaxSubclass using default value: 3
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getByte
WARNING: [Character.ini] missing property for key: BaseSubclassLevel using default value: 40
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getByte
WARNING: [Character.ini] missing property for key: MaxSubclassLevel using default value: 80
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaxPvtStoreSellSlotsDwarf using default value: 4
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaxPvtStoreSellSlotsOther using default value: 3
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaxPvtStoreBuySlotsDwarf using default value: 5
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaxPvtStoreBuySlotsOther using default value: 4
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaximumSlotsForNoDwarf using default value: 80
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaximumSlotsForDwarf using default value: 100
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaximumSlotsForGMPlayer using default value: 250
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaximumSlotsForQuestItems using default value: 100
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaximumWarehouseSlotsForDwarf using default value: 120
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaximumWarehouseSlotsForNoDwarf using default value: 100
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaximumWarehouseSlotsForClan using default value: 150
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaximumFreightSlots using default value: 200
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: FreightPrice using default value: 1000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: EnchantChanceElementStone using default value: 50.0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: EnchantChanceElementCrystal using default value: 30.0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: EnchantChanceElementJewel using default value: 20.0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: EnchantChanceElementEnergy using default value: 10.0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Character.ini] missing property for key: EnchantBlackList using default value: 7816,7817,7818,7819,7820,7821,7822,7823,7824,7825,7826,7827,7828,7829,7830,7831,13293,13294,13296
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: DisableOverEnchanting using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: AugmentationNGSkillChance using default value: 15
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: AugmentationNGGlowChance using default value: 0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: AugmentationMidSkillChance using default value: 30
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: AugmentationMidGlowChance using default value: 40
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: AugmentationHighSkillChance using default value: 45
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: AugmentationHighGlowChance using default value: 70
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: AugmentationTopSkillChance using default value: 60
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: AugmentationTopGlowChance using default value: 100
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: AugmentationBaseStatChance using default value: 1
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: AugmentationAccSkillChance using default value: 0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: RetailLikeAugmentation using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Character.ini] missing property for key: RetailLikeAugmentationNoGradeChance using default value: 55,35,7,3
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Character.ini] missing property for key: RetailLikeAugmentationMidGradeChance using default value: 55,35,7,3
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Character.ini] missing property for key: RetailLikeAugmentationHighGradeChance using default value: 55,35,7,3
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Character.ini] missing property for key: RetailLikeAugmentationTopGradeChance using default value: 55,35,7,3
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: RetailLikeAugmentationAccessory using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Character.ini] missing property for key: AugmentationBlackList using default value: 6656,6657,6658,6659,6660,6661,6662,8191,10170,10314,13740,13741,13742,13743,13744,13745,13746,13747,13748,14592,14593,14594,14595,14596,14597,14598,14599,14600,14664,14665,14666,14667,14668,14669,14670,14671,14672,14801,14802,14803,14804,14805,14806,14807,14808,14809,15282,15283,15284,15285,15286,15287,15288,15289,15290,15291,15292,15293,15294,15295,15296,15297,15298,15299,16025,16026,21712,22173,22174,22175
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltAllowAugmentPvPItems using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltKarmaPlayerCanBeKilledInPeaceZone using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltKarmaPlayerCanShop using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltKarmaPlayerCanTeleport using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltKarmaPlayerCanUseGK using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltKarmaPlayerCanTrade using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltKarmaPlayerCanUseWareHouse using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaxPersonalFamePoints using default value: 100000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: FortressZoneFameTaskFrequency using default value: 300
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: FortressZoneFameAquirePoints using default value: 31
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: CastleZoneFameTaskFrequency using default value: 300
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: CastleZoneFameAquirePoints using default value: 125
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: FameForDeadPlayers using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: CraftingEnabled using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: CraftMasterwork using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: DwarfRecipeLimit using default value: 50
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: CommonRecipeLimit using default value: 50
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltGameCreation using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: AltGameCreationSpeed using default value: 1.0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: AltGameCreationXpRate using default value: 1.0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: AltGameCreationSpRate using default value: 1.0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: AltGameCreationRareXpSpRate using default value: 2.0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltBlacksmithUseRecipes using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: AltClanLeaderDateChange using default value: 3
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Character.ini] missing property for key: AltClanLeaderHourChange using default value: 00:00:00
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltClanLeaderInstantActivation using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: DaysBeforeJoinAClan using default value: 1
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: DaysBeforeCreateAClan using default value: 10
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: DaysToPassToDissolveAClan using default value: 7
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: DaysBeforeJoinAllyWhenLeaved using default value: 1
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: DaysBeforeJoinAllyWhenDismissed using default value: 1
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: DaysBeforeAcceptNewClanWhenDismissed using default value: 1
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: DaysBeforeCreateNewAllyWhenDissolved using default value: 1
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: AltMaxNumOfClansInAlly using default value: 3
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: AltClanMembersForWar using default value: 15
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltMembersCanWithdrawFromClanWH using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: RemoveCastleCirclets using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: AltPartyRange using default value: 1600
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: AltPartyRange2 using default value: 1400
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltLeavePartyLeader using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: InitialEquipmentEvent using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Character.ini] missing property for key: StartingAdena using default value: 0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getByte
WARNING: [Character.ini] missing property for key: StartingLevel using default value: 1
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: StartingSP using default value: 0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getLong
WARNING: [Character.ini] missing property for key: MaxAdena using default value: 99900000000
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AutoLoot using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AutoLootRaids using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AutoLootSlotLimit using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: RaidLootRightsInterval using default value: 900
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: RaidLootRightsCCSize using default value: 45
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Character.ini] missing property for key: AutoLootItemIds using default value: 0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: KeyboardMovement using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: UnstuckInterval using default value: 300
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: TeleportWatchdogTimeout using default value: 0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: PlayerSpawnProtection using default value: 0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: PlayerTeleportProtection using default value: 0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: RandomRespawnInTownEnabled using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: OffsetOnTeleportEnabled using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaxOffsetOnTeleport using default value: 50
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: PetitioningAllowed using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaxPetitionsPerPlayer using default value: 5
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: MaxPetitionsPending using default value: 25
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: FreeTeleporting using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: DeleteCharAfterDays using default value: 7
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Character.ini] missing property for key: PartyXpCutoffMethod using default value: highfive
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getDouble
WARNING: [Character.ini] missing property for key: PartyXpCutoffPercent using default value: 3.0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: PartyXpCutoffLevel using default value: 20
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Character.ini] missing property for key: PartyXpCutoffGaps using default value: 0,9;10,14;15,99
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Character.ini] missing property for key: PartyXpCutoffGapPercent using default value: 100;30;0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: DisableTutorial using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: ExpertisePenalty using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: StoreRecipeShopList using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: StoreCharUiSettings using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Character.ini] missing property for key: ForbiddenNames using default value:
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: SilenceModeExclude using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: AltValidateTriggerSkills using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: NpcTalkBlockingTime using default value: 0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: NevitEnabled using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: NevitMaxPoints using default value: 7200
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: NevitBonusEffectTime using default value: 180
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Character.ini] missing property for key: NevitAdventTime using default value: 14400
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Character.ini] missing property for key: NevitIgnoreAdventTime using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser <init>
WARNING: [Telnet.ini] There was an error loading config reason: \config\Telnet.ini (Системе не удается найти указанный путь)
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [Telnet.ini] missing property for key: EnableTelnet using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [Telnet.ini] missing property for key: Port using default value: 12345
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Telnet.ini] missing property for key: BindAddress using default value: 127.0.0.1
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Telnet.ini] missing property for key: Password using default value:
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [Telnet.ini] missing property for key: ListOfHosts using default value: 127.0.0.1,::1
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser <init>
WARNING: [IdFactory.ini] There was an error loading config reason: \config\IdFactory.ini (Системе не удается найти указанный путь)
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getEnum
WARNING: [IdFactory.ini] missing property for key: IDFactory using default value: BitSet
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [IdFactory.ini] missing property for key: BadIdChecking using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser <init>
WARNING: [General.ini] There was an error loading config reason: \config\General.ini (Системе не удается найти указанный путь)
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: EverybodyHasAdminRights using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: ServerGMOnly using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GMHeroAura using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GMStartupBuilderHide using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GMStartupInvulnerable using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GMStartupInvisible using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GMStartupSilence using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GMStartupAutoList using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GMStartupDietMode using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GMItemRestriction using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GMSkillRestriction using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GMTradeRestrictedItems using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GMRestartFighting using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GMShowAnnouncerName using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GMShowCritAnnouncerName using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GMGiveSpecialSkills using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GMGiveSpecialAuraSkills using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GMDebugHtmlPaths using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: UseSuperHasteAsGMSpeed using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: LogChat using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: LogAutoAnnouncements using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: LogItems using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: LogItemsSmallLog using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: LogItemEnchants using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: LogSkillEnchants using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GMAudit using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: SkillCheckEnable using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: SkillCheckRemove using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: SkillCheckGM using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: HtmlActionCacheDebug using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: PacketHandlerDebug using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: Developer using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AltDevNoHandlers using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AltDevNoQuests using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AltDevNoSpawns using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AltDevShowQuestsLoadInLogs using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AltDevShowScriptsLoadInLogs using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AllowDiscardItem using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: AutoDestroyDroppedItemAfter using default value: 600
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: AutoDestroyHerbTime using default value: 60
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getString
WARNING: [General.ini] missing property for key: ListOfProtectedItems using default value: 0
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: DatabaseCleanUp using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: CharacterDataStoreInterval using default value: 15
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: LazyItemsUpdate using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: UpdateItemsOnCharStore using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: DestroyPlayerDroppedItem using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: DestroyEquipableItem using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: DestroyAllItems using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: SaveDroppedItem using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: EmptyDroppedItemTableAfterLoad using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: SaveDroppedItemInterval using default value: 60
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: ClearDroppedItemTable using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AutoDeleteInvalidQuestData using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: MultipleItemDrop using default value: true
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: ForceInventoryUpdate using default value: false
мая 21, 2019 2:34:27 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: LazyCache using default value: true
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: CacheCharNames using default value: true
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: MinNPCAnimation using default value: 10
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: MaxNPCAnimation using default value: 20
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: MinMonsterAnimation using default value: 5
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: MaxMonsterAnimation using default value: 20
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: GridsAlwaysOn using default value: false
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: GridNeighborTurnOnTime using default value: 1
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: GridNeighborTurnOffTime using default value: 90
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: PeaceZoneMode using default value: 0
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getString
WARNING: [General.ini] missing property for key: GlobalChat using default value: ON
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getString
WARNING: [General.ini] missing property for key: TradeChat using default value: ON
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: MinimumChatLevel using default value: 0
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AllowWarehouse using default value: true
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: WarehouseCache using default value: false
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: WarehouseCacheTime using default value: 15
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AllowRefund using default value: true
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AllowMail using default value: true
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AllowAttachments using default value: true
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AllowWear using default value: true
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: WearDelay using default value: 5
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: WearPrice using default value: 10
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: DefaultFinishTime using default value: 300
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: RestorePlayerInstance using default value: false
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AllowSummonInInstance using default value: false
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: EjectDeadPlayerTime using default value: 60
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AllowLottery using default value: true
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AllowRace using default value: true
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AllowWater using default value: true
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AllowRentPet using default value: false
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AllowFishing using default value: true
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AllowManor using default value: true
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AllowBoat using default value: true
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getInt
WARNING: [General.ini] missing property for key: BoatBroadcastRadius using default value: 20000
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: AllowCursedWeapons using default value: true
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: ShowServerNews using default value: false
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: EnableCommunityBoard using default value: true
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getString
WARNING: [General.ini] missing property for key: BBSDefault using default value: _bbshome
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getBoolean
WARNING: [General.ini] missing property for key: UseChatFilter using default value: false
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getString
WARNING: [General.ini] missing property for key: ChatFilterChars using default value: ^_^
мая 21, 2019 2:34:28 ПП l2j.commons.util.PropertiesParser getString
WARNING: [General.ini] missing property for key: BanChatChannels using default value: GENERAL;SHOUT;WORLD;TRADE;HERO_VOICE
Exception in thread "main" java.lang.IllegalArgumentException: No enum constant l2j.gameserver.enums.ChatType.WORLD
    at java.base/java.lang.Enum.valueOf(Enum.java:240)
    at l2j.Config.load(Config.java:2076)
    at l2j.gameserver.GameServer.<init>(GameServer.java:158)
    at l2j.gameserver.GameServer.main(GameServer.java:454)

Process finished with exit code 1
 
я выделил
 

Вложения

  • Безымянный.jpg
    Безымянный.jpg
    46,9 КБ · Просмотры: 107
вот и указать путь до dist/game для game и для логина по тому же принципу. Должно помочь 😉
 
  • Мне нравится
Реакции: Psycho

    Psycho

    Баллов: 27
    Помог
вот и указать путь до dist/game для game и для логина по тому же принципу. Должно помочь 😉
Указал, без толку.
Он перестает видеть мейн класс.

Кстати, не подскажешь, че это за варнинг такой?
screen.jpg
 
kotlin - яп от JetBrains, работающий поверх JVM.
 
мая 21, 2019 1:54:19 ПП l2j.loginserver.LoginServer <init>
WARNING: LoginServer: .\log.cfg (Не удается найти указанный файл)

Такие ерроры у меня были, пока я абсолютные пути не прописал
 
мая 21, 2019 1:54:19 ПП l2j.loginserver.LoginServer <init>
WARNING: LoginServer: .\log.cfg (Не удается найти указанный файл)

Такие ерроры у меня были, пока я абсолютные пути не прописал
А без такой дичи ни как?
 
А без такой дичи ни как?
хз, я не особый спец в яве :D
Когда баловался компилами, сорцами (чисто для себя) - приходилось вручную пилить абсолютные пути, ибо почему-то более 90% сборок не хотели видеть путь без абсолютного адреса типа как /root/server/data/java/jopa.txt
 
Бле, я хз, через батники стартует без проблем.
 

Вложения

  • Shot00000.jpg
    Shot00000.jpg
    219,4 КБ · Просмотры: 61
  • screen.jpg
    screen.jpg
    164,9 КБ · Просмотры: 58
Без замены пути импортов стартует. Значит сам где-то накосячил. Трид в помойку, всем спасибо.
Код:
[main] INFO com.zaxxer.hikari.HikariDataSource - HikariPool-1 - Starting...
[main] INFO com.zaxxer.hikari.HikariDataSource - HikariPool-1 - Start completed.
[21/05 18:51:35] Database: Initialized.
[21/05 18:51:35] Loading LoginController...
[21/05 18:51:36] Cached 10 KeyPairs for RSA communication.
[21/05 18:51:36] Loaded 127 server names.
[21/05 18:51:36] Loaded 1 registered Game Servers.
[21/05 18:51:36] Cached 10 RSA keys for Game Server communication.
[21/05 18:51:36] Loaded 2 IP Bans.
[21/05 18:51:36] Listening for GameServers on 127.0.0.1:9014
[21/05 18:51:37] ClientNetworkManager: Listening on 0.0.0.0:2106
Код:
[21/05 18:55:54] Network Config: ipconfig.xml doesn't exists using automatic configuration...
[21/05 18:55:55] Network Config: Adding new subnet: 127.0.0.0/8 address: 127.0.0.1
[21/05 18:55:55] Network Config: Adding new subnet: 192.168.1.0/24 address: 192.168.1.67
[21/05 18:55:55] Network Config: Adding new subnet: 0.0.0.0/0 address: 128.70.109.39
[21/05 18:55:55] Loaded 6 Filter Words.
[21/05 18:55:55] ------------------------------------------------=[ Database ]
[main] INFO com.zaxxer.hikari.HikariDataSource - HikariPool-1 - Starting...
[main] INFO com.zaxxer.hikari.HikariDataSource - HikariPool-1 - Start completed.
[21/05 18:55:55] Database: Initialized.
[21/05 18:55:55] ----------------------------------------------=[ ThreadPool ]
[21/05 18:55:55] ThreadPool: Initialized
[21/05 18:55:55] ...4 scheduled pool executors with 16 total threads.
[21/05 18:55:55] ...4 instant pool executors with 8 total threads.
[21/05 18:55:55] -----------------------------------------------=[ IdFactory ]
[21/05 18:55:55] Updated characters online status.
[21/05 18:55:56] Cleaned 0 elements from database in 0 s
[21/05 18:55:56] Cleaned 0 expired timestamps from database.
[21/05 18:55:56] BitSetIDFactory: 102912 id's available.
[21/05 18:55:56] ----------------------------------------=[ Scripting Engine ]
[21/05 18:55:56] ScriptEngine: Java Engine 10 (Java [3, 4, 5, 6, 7, 8, 9, 10])
[21/05 18:55:57] Loaded 5 files to exclude.
[21/05 18:55:57] --------------------------------------------------=[ Telnet ]
[21/05 18:55:58] Telnet server is currently disabled.
[21/05 18:55:58] ---------------------------------------------------=[ World ]
[21/05 18:55:58] GameTimeController: Started.
[21/05 18:55:58] InstanceManager: Multiverse Instance created.
[21/05 18:55:58] InstanceManager: Universe Instance created.
[21/05 18:55:58] InstanceManager: Loaded 160 instance names.
[21/05 18:55:59] InstanceManager: Loaded 126 instance templates.
[21/05 18:55:59] L2World: (256 by 272) World Region Grid set up.
[21/05 18:56:00] MapRegionManager: Loaded 57 map regions.
[21/05 18:56:00] GlobalVariablesManager: Loaded 2 variables.
[21/05 18:56:00] ----------------------------------------------------=[ Data ]
[21/05 18:56:00] CategoryData: Loaded 180 Categories.
[21/05 18:56:00] SecondaryAuthData: Loaded 328 forbidden passwords.
[21/05 18:56:00] --------------------------------------------------=[ Skills ]
[21/05 18:56:09] EffectMasterHandler: Loaded 160 effect handlers.
[21/05 18:56:09] EnchantSkillGroupsData: Loaded 4 groups and 90 routes.
[21/05 18:56:10] SkillTreesData: Loaded 17176 Class Skills for 103 Class Skill Trees.
[21/05 18:56:10] SkillTreesData: Loaded 76 Sub-Class Skills.
[21/05 18:56:10] SkillTreesData: Loaded 77 Transfer Skills for 3 Transfer Skill Trees.
[21/05 18:56:10] SkillTreesData: Loaded 117 Fishing Skills, 8 Dwarven only Fishing Skills.
[21/05 18:56:10] SkillTreesData: Loaded 3 Collect Skills.
[21/05 18:56:10] SkillTreesData: Loaded 74 Pledge Skills, 44 for Pledge and 30 Residential.
[21/05 18:56:10] SkillTreesData: Loaded 18 Sub-Pledge Skills.
[21/05 18:56:10] SkillTreesData: Loaded 32 Transform Skills.
[21/05 18:56:10] SkillTreesData: Loaded 8 Noble Skills.
[21/05 18:56:10] SkillTreesData: Loaded 5 Hero Skills.
[21/05 18:56:10] SkillTreesData: Loaded 46 Game Master Skills.
[21/05 18:56:10] SkillTreesData: Loaded 46 Game Master Aura Skills.
[21/05 18:56:19] DocumentEngine: Loaded 65961 Skill templates from XML files.
[21/05 18:56:19] PetSkillData: Loaded 881 skills.
[21/05 18:56:19] ---------------------------------------------------=[ Items ]
[21/05 18:56:22] ItemTable: Highest item id used: 22567
[21/05 18:56:22] ItemTable: Loaded: 11481 Etc Items
[21/05 18:56:22] ItemTable: Loaded: 3825 Armor Items
[21/05 18:56:22] ItemTable: Loaded: 3893 Weapon Items
[21/05 18:56:22] ItemTable: Loaded: 19199 Items in total.
[21/05 18:56:22] EnchantItemGroupsData: Loaded: 4 item group templates.
[21/05 18:56:22] EnchantItemGroupsData: Loaded: 1 scroll group templates.
[21/05 18:56:22] EnchantItemData: Loaded 63 Enchant Scrolls.
[21/05 18:56:22] EnchantItemData: Loaded 20 Support Items.
[21/05 18:56:22] EnchantItemOptionsData: Loaded: 23 Items and 1093 Options.
[21/05 18:56:25] OptionData: Loaded: 24985 Options.
[21/05 18:56:25] EnchantItemHPBonusData: Loaded 6 Enchant HP Bonuses.
[21/05 18:56:25] MerchantPriceConfigTable: Loaded 28 merchant price configs.
[21/05 18:56:29] Folder D:\Lineage 2\hf\dist\game\data\buylists\custom doesn't exist!
[21/05 18:56:29] BuyListData: Loaded 760 BuyLists.
[21/05 18:56:30] Folder D:\Lineage 2\hf\dist\game\data\multisell\custom doesn't exist!
[21/05 18:56:30] MultisellData: Loaded 192 multisell lists.
[21/05 18:56:30] RecipeData: Loaded 1000 recipes.
[21/05 18:56:30] ArmorSetsData: Loaded 198 Armor sets.
[21/05 18:56:31] FishData: Loaded 278 Fishes.
[21/05 18:56:31] FishingMonstersData: Loaded 8 Fishing Monsters.
[21/05 18:56:31] FishingRodsData: Loaded 6 Fishing Rods.
[21/05 18:56:31] HennaData: Loaded 180 Henna data.
[21/05 18:56:31] ----------------------------------------------=[ Characters ]
[21/05 18:56:31] ClassListData: Loaded 107 Class data.
[21/05 18:56:31] InitialEquipmentData: Loaded 11 Initial Equipment data.
[21/05 18:56:31] InitialShortcutData: Loaded 5 Initial Global Shortcuts data.
[21/05 18:56:31] InitialShortcutData: Loaded 4 Initial Shortcuts data.
[21/05 18:56:31] InitialShortcutData: Loaded 0 Macros presets.
[21/05 18:56:31] ExperienceData: Loaded 87 levels.
[21/05 18:56:31] ExperienceData: Max Player Level is: 85
[21/05 18:56:31] ExperienceData: Max Pet Level is: 86
[21/05 18:56:31] KarmaData: Loaded 85 karma modifiers.
[21/05 18:56:31] HitConditionBonusData: Loaded Hit Condition bonuses.
[21/05 18:56:32] PlayerTemplateData: Loaded 103 character templates.
[21/05 18:56:32] PlayerTemplateData: Loaded 52530 level up gain records.
[21/05 18:56:32] CharNameTable: Loaded 1 char names.
[21/05 18:56:32] AdminData: Loaded: 10 Access Levels.
[21/05 18:56:32] AdminData: Loaded: 456 Access Commands.
[21/05 18:56:32] RaidBossPointsManager: Loaded 0 Characters Raid Points.
[21/05 18:56:33] PetDataTable: Loaded 49 Pets.
[21/05 18:56:33] ---------------------------------------------------=[ Clans ]
[21/05 18:56:33] ForumsBBSManager: Loaded 4 forums. Last forum id used: 4
[21/05 18:56:33] ClanTable: Restored 0 clans from the database.
[21/05 18:56:33] CHSiegeManager: Loaded 6 conquerable clan halls.
[21/05 18:56:33] ClanHallAuctionManager: Loaded: 38 auction(s)
[21/05 18:56:33] ClanHallManager: Loaded: 0 clan halls
[21/05 18:56:33] ClanHallManager: Loaded: 38 free clan halls
[21/05 18:56:33] -------------------------------------------------=[ Geodata ]
[21/05 18:56:33] GeoEngine: Initializing...
[21/05 18:56:33] GeoEngine: Loaded 0 geodata files.
[21/05 18:56:33] GeoEngine: Forcing PathFinding setting to false.
[21/05 18:56:33] GeoEngine: Forcing CoordSynchronize setting to -1.
[21/05 18:56:34] GeoEnginePathfinding: Loaded 32 node buffers.
[21/05 18:56:34] ----------------------------------------------------=[ NPCs ]
[21/05 18:56:34] ZoneManager 17 by 18 Zone Region Grid set up.
[21/05 18:56:40] NpcData: Loaded 10461 NPCs.
[21/05 18:56:40] NpcData: Loaded 13 Custom NPCs.
[21/05 18:56:41] SkillLearnData: Loaded 256 Skill Learn data.
[21/05 18:56:41] GrandBossManager: Gigantic Chaos Golem(25512) status is 0.
[21/05 18:56:41] GrandBossManager: Queen Ant(29001) status is 0.
[21/05 18:56:41] GrandBossManager: Core(29006) status is 0.
[21/05 18:56:41] GrandBossManager: Orfen(29014) status is 0.
[21/05 18:56:41] GrandBossManager: Baium(29020) status is 0.
[21/05 18:56:41] GrandBossManager: Valakas(29028) status is 0.
[21/05 18:56:41] GrandBossManager: Antharas(29068) status is 0.
[21/05 18:56:41] GrandBossManager: Beleth(29118) status is 0.
[21/05 18:56:41] GrandBossManager: Loaded 8 Instances
[21/05 18:56:41] ZoneManager: Loaded 29 zone classes and 2854 zones.
[21/05 18:56:41] ZoneManager: Loaded 731 NPC spawn territoriers.
[21/05 18:56:41] ZoneManager: Last static id: 200105
[21/05 18:56:42] DoorData: Loaded 1301 Door Templates for 22 regions.
[21/05 18:56:42] Loaded 1 Fences.
[21/05 18:56:42] FakePlayerData: Disabled.
[21/05 18:56:42] FakePlayerChatManager: Disabled.
[21/05 18:56:43] WalkingManager: Loaded 123 walking routes.
[21/05 18:56:43] StaticObjectData: Loaded 51 static object templates.
[21/05 18:56:43] ItemAuctionInstance: Loaded 82 item(s) and registered 1 auction(s) for instance 32320.
[21/05 18:56:43] ItemAuctionInstance: Schedule next auction 1 on 17:00:00 24.05.19 for instance 32320
[21/05 18:56:43] ItemAuctionInstance: Loaded 82 item(s) and registered 1 auction(s) for instance 32321.
[21/05 18:56:43] ItemAuctionInstance: Schedule next auction 2 on 17:00:00 27.05.19 for instance 32321
[21/05 18:56:43] ItemAuctionInstance: Loaded 82 item(s) and registered 1 auction(s) for instance 32322.
[21/05 18:56:43] ItemAuctionInstance: Schedule next auction 3 on 17:00:00 22.05.19 for instance 32322
[21/05 18:56:43] ItemAuctionManager: Loaded 3 instance(s).
[21/05 18:56:43] CastleManager: Loaded: 9 castles
[21/05 18:56:43] SchemeBufferTable: Loaded 0 players schemes and 60 available buffs.
[21/05 18:56:43] GrandBossManager: Initialized 12 Grand Boss Zones
[21/05 18:56:43] ------------------------------------------------=[ Olympiad ]
[21/05 18:56:43] Olympiad System: failed to load data from database, trying to load from file.
[21/05 18:56:43] Olympiad System: Loading Olympiad System....
[21/05 18:56:43] Olympiad System: Currently in Olympiad Period
[21/05 18:56:43] Olympiad System: 15423 minutes until period ends
[21/05 18:56:43] Olympiad System: Next weekly change is in 10079 minutes
[21/05 18:56:43] Olympiad System: Loaded 0 Nobles
[21/05 18:56:43] Olympiad System: Competition Period Starts in 0 days, 0 hours and 0 mins.
[21/05 18:56:43] Olympiad System: Event starts/started : Tue May 21 18:00:43 GMT+03:00 2019
[21/05 18:56:43] Olympiad System: Olympiad Game Started
[21/05 18:56:43] Hero System: Loaded 0 Heroes.
[21/05 18:56:43] Hero System: Loaded 0 all time Heroes.
[21/05 18:56:43] ---------------------------------------------=[ Seven Signs ]
[21/05 18:56:43] SevenSigns: Currently in the Competition (Quest Event) period!
[21/05 18:56:43] SevenSigns: The Seal of Avarice remains unclaimed.
[21/05 18:56:43] SevenSigns: The Seal of Gnosis remains unclaimed.
[21/05 18:56:43] SevenSigns: The Seal of Strife remains unclaimed.
[21/05 18:56:43] SevenSigns: The competition, if the current trend continues, will end in a tie this week.
[21/05 18:56:43] SevenSigns: Next period change set to Mon May 27 18:00:43 GMT+03:00 2019
[21/05 18:56:43] SevenSigns: Next period begins in 5 days, 23 hours and 3 mins.
[21/05 18:56:43] ---------------------------------------------------=[ Cache ]
[21/05 18:56:43] Html cache start...
[21/05 18:56:44] Olympiad System: Loaded 160 stadiums.
[21/05 18:56:55] Cache[HTML]: 9,269 megabytes on 20641 files loaded
[21/05 18:56:55] CrestTable: Loaded 0 Crests.
[21/05 18:56:55] TeleportLocationTable: Loaded 957 Teleport Location Templates.
[21/05 18:56:55] UIData: Loaded 4 keys 5 categories.
[21/05 18:56:55] AugmentationData: Loaded: 33960 augmentations.
[21/05 18:56:55] AugmentationData: Loaded: 2754 accessory augmentations.
[21/05 18:56:56] CursedWeaponsManager: Loaded : 2 cursed weapon(s).
[21/05 18:56:57] TransformData: Loaded: 111 transform templates.
[21/05 18:56:57] BotReportTable: Loaded 0 bot reports
[21/05 18:56:57] -------------------------------------------------=[ Scripts ]
[21/05 18:56:57] AirShipManager: Loaded 0 private airships
[21/05 18:56:57] Seed of Destruction Manager: Loaded. Current stage is: 1
[21/05 18:56:57] Seed of Infinity Manager: Loaded. Current stage is: 1
[21/05 18:56:57] Loading server scripts...
[21/05 18:57:03] Loading Handlers...
[21/05 18:57:04] ActionHandler: Loaded 10 Handlers
[21/05 18:57:04] ActionShiftHandler: Loaded 6 Handlers
[21/05 18:57:04] AdminCommandHandler: Loaded 459 Handlers
[21/05 18:57:04] BypassHandler: Loaded 49 Handlers
[21/05 18:57:04] ChatHandler: Loaded 14 Handlers
[21/05 18:57:04] CommunityBoardHandler: Loaded 24 Handlers
[21/05 18:57:04] ItemHandler: Loaded 30 Handlers
[21/05 18:57:04] PunishmentHandler: Loaded 3 Handlers
[21/05 18:57:04] UserCommandHandler: Loaded 17 Handlers
[21/05 18:57:04] VoicedCommandHandler: Loaded 7 Handlers
[21/05 18:57:04] TargetHandler: Loaded 34 Handlers
[21/05 18:57:04] Handlers Loaded...
[21/05 18:57:24] Handy's Block Checker Event is enabled
[21/05 18:57:24] Fantasy Isle: Parade starting at 2019/05/21 21:20 and is scheduled each next 1 hours.
[21/05 18:57:24] Fantasy Isle: MC show script starting at 21/05/2019 22:43:24 and is scheduled each next 4 hours.
[21/05 18:57:24] GraciaLoader: Loading Gracia related scripts.
[21/05 18:57:25] HellboundLoader: Loading Hellbound related scripts:
[21/05 18:57:25] HellboundPointData: Loaded 47 trust point reward data.
[21/05 18:57:25] HellboundSpawns: Loaded 598 Hellbound spawns.
[21/05 18:57:25] HellboundEngine: Level: 11
[21/05 18:57:25] HellboundEngine: Trust: 4000000
[21/05 18:57:25] HellboundEngine: Status: unlocked.
[21/05 18:57:25] RaidBossSpawnManager: Loaded 187 Instances
[21/05 18:57:25] RaidBossSpawnManager: Scheduled 0 Instances
[21/05 18:57:25] NpcBuffersData: Loaded: 33 buffers data.
[21/05 18:57:26] Devastated Castle siege scheduled for Tue Jun 04 12:00:00 GMT+03:00 2019.
[21/05 18:57:26] Bandit StrongHold siege scheduled for Tue Jun 04 12:00:00 GMT+03:00 2019.
[21/05 18:57:26] Beast Farm siege scheduled for Tue Jun 04 12:00:00 GMT+03:00 2019.
[21/05 18:57:26] Fortress of Resistance siege scheduled for Tue Jun 04 12:00:00 GMT+03:00 2019.
[21/05 18:57:26] Fortresss of the Dead siege scheduled for Tue Jun 04 12:00:00 GMT+03:00 2019.
[21/05 18:57:26] Rainbow Springs siege scheduled for Tue Jun 04 12:00:00 GMT+03:00 2019.
[21/05 18:57:26] HellboundEngine: Spawned 598 NPCs.
[21/05 18:57:26] Event Freya Celebration has passed... Ignored
[21/05 18:57:26] Event Gift of Vitality has passed... Ignored
[21/05 18:57:26] Event Heavy Medal has passed... Ignored
[21/05 18:57:26] Event L2 Day has passed... Ignored
[21/05 18:57:26] Event Love Your Gatekeeper has passed... Ignored
[21/05 18:57:26] Event Master of Enchanting has passed... Ignored
[21/05 18:57:26] Event Valentine Event has passed... Ignored
[21/05 18:57:26] [Final Emperial Tomb] Loaded 26 spawn zones data.
[21/05 18:57:26] [Final Emperial Tomb] Loaded 94 spawns data.
[21/05 18:57:27] [EnhanceYourWeapon] Loaded 54 Soul Crystal data.
[21/05 18:57:27] [EnhanceYourWeapon] Loaded 240 npc Leveling info data.
[21/05 18:57:28] TerritoryWarSuperClass: Siege date: Sun May 26 22:00:00 GMT+03:00 2019
[21/05 18:57:28] SpawnTable: Initializing spawns...
[21/05 18:57:32] SpawnTable: 41068 spawns have been initialized!
[21/05 18:57:32] DayNightSpawnManager: Removed 0 night creatures
[21/05 18:57:32] DayNightSpawnManager: Spawned 232 day creatures
[21/05 18:57:32] FourSepulchersManager: loaded 20 Mysterious-Box spawns.
[21/05 18:57:32] FourSepulchersManager: loaded 716 Physical type monsters spawns.
[21/05 18:57:32] FourSepulchersManager: loaded 716 Magical type monsters spawns.
[21/05 18:57:32] FourSepulchersManager: loaded 92 Church of duke monsters spawns.
[21/05 18:57:32] FourSepulchersManager: loaded 68 Emperor's grave NPC spawns.
[21/05 18:57:32] FourSepulchersManager: spawned Conquerors' Sepulcher Manager
[21/05 18:57:32] FourSepulchersManager: spawned Emperors' Sepulcher Manager
[21/05 18:57:32] FourSepulchersManager: spawned Great Sages' Sepulcher Manager
[21/05 18:57:32] FourSepulchersManager: spawned Judges' Sepulcher Manager
[21/05 18:57:32] FourSepulchersManager: Beginning in Entry time
[21/05 18:57:33] DimensionalRiftManager: Loaded 7 room types with 56 rooms.
[21/05 18:57:33] DimensionalRiftManager: Loaded 462 dimensional rift spawns, 0 errors.
[21/05 18:57:33] VoteSystem: Disabled.
[21/05 18:57:33] ---------------------------------------------------=[ Siege ]
[21/05 18:57:33] Siege of Gludio: Sun May 26 16:00:00 GMT+03:00 2019
[21/05 18:57:33] Siege of Dion: Sun May 26 16:00:00 GMT+03:00 2019
[21/05 18:57:33] Siege of Giran: Sun May 26 16:00:00 GMT+03:00 2019
[21/05 18:57:33] Siege of Oren: Sun May 26 16:00:00 GMT+03:00 2019
[21/05 18:57:33] Siege of Aden: Sun May 26 16:00:00 GMT+03:00 2019
[21/05 18:57:33] Siege of Innadril: Sun May 26 20:00:00 GMT+03:00 2019
[21/05 18:57:33] Siege of Goddard: Sun May 26 20:00:00 GMT+03:00 2019
[21/05 18:57:33] Siege of Rune: Sun May 26 20:00:00 GMT+03:00 2019
[21/05 18:57:33] Siege of Schuttgart: Sun May 26 20:00:00 GMT+03:00 2019
[21/05 18:57:33] FortManager: Loaded: 21 fortress
[21/05 18:57:33] SiegeScheduleData: Loaded: 2 siege schedulers.
[21/05 18:57:33] CastleManorManager: Loaded 258 seeds.
[21/05 18:57:33] CastleManorManager: Manor data loaded.
[21/05 18:57:33] MercTicketManager: Loaded: 0 Mercenary Tickets
[21/05 18:57:33] QuestManager: Loaded: 525 quests.
[21/05 18:57:33] QuestManager: Loaded: 289 scripts.
[21/05 18:57:34] SevenSignsFestival: The first Festival of Darkness cycle begins in 2 minute(s).
[21/05 18:57:34] AutoSpawnHandler: Loaded 129 handlers in total.
[21/05 18:57:34] FishingChampionshipManager : new event period start.
[21/05 18:57:34] TaskManager: Loaded: 12 Tasks.
[21/05 18:57:34] MailManager: Successfully loaded 0 messages.
[21/05 18:57:34] PunishmentManager: Loaded 0 active and 0 expired punishments.
[21/05 18:57:34] IdFactory: Free ObjectID's remaining: 1878999817
[21/05 18:57:34] TvTEventEngine[TvTManager.TvTManager()]: Engine is disabled.
[21/05 18:57:34] OfflineTradersTable: Loading offline traders...
[21/05 18:57:34] OfflineTradersTable: Loaded: 0 offline trader(s)
[21/05 18:57:35] GameServer: Started, using 688 of 2034 MB total memory.
[21/05 18:57:35] GameServer: Geodata use 38 MB of memory.
[21/05 18:57:35] GameServer: Maximum number of connected players is 2000.
[21/05 18:57:35] GameServer: Server loaded in 101 seconds.
[21/05 18:57:39] ClientNetworkManager: Listening on 0.0.0.0:7777
[21/05 18:57:40] LoginServerThread: Connecting to login on 127.0.0.1:9014
[21/05 18:57:41] LoginServerThread: Registered on login as Server 2: Sieghardt

з.ы. с импортами тоже разобрался, теперь всё нормально фурычет.
 
Последнее редактирование:
Назад
Сверху Снизу