/* * This program is free software: you can redistribute it and/or modify it under * the terms of the GNU General Public License as published by the Free Software * Foundation, either version 3 of the License, or (at your option) any later * version. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more * details. * * You should have received a copy of the GNU General Public License along with * this program. If not, see . */ package handlers.admincommandhandlers; import java.util.StringTokenizer; import java.util.logging.Logger; import javolution.text.TextBuilder; import com.l2jserver.Config; import com.l2jserver.gameserver.GmListTable; import com.l2jserver.gameserver.cache.HtmCache; import com.l2jserver.gameserver.datatables.AccessLevels; import com.l2jserver.gameserver.datatables.AdminCommandAccessRights; import com.l2jserver.gameserver.datatables.DoorTable; import com.l2jserver.gameserver.datatables.ItemTable; import com.l2jserver.gameserver.datatables.MultiSell; import com.l2jserver.gameserver.datatables.NpcTable; import com.l2jserver.gameserver.datatables.NpcWalkerRoutesTable; import com.l2jserver.gameserver.datatables.SkillTable; import com.l2jserver.gameserver.datatables.SpawnTable; import com.l2jserver.gameserver.datatables.TeleportLocationTable; import com.l2jserver.gameserver.handler.IAdminCommandHandler; import com.l2jserver.gameserver.instancemanager.Manager; import com.l2jserver.gameserver.instancemanager.QuestManager; import com.l2jserver.gameserver.model.L2Spawn; import com.l2jserver.gameserver.model.actor.instance.L2PcInstance; import com.l2jserver.gameserver.model.olympiad.Olympiad; import com.l2jserver.gameserver.network.SystemMessageId; import com.l2jserver.gameserver.network.serverpackets.NpcHtmlMessage; /** * This class handles following admin commands: * - admin|admin1/admin2/admin3/admin4/admin5 = slots for the 5 starting admin menus * - gmliston/gmlistoff = includes/excludes active character from /gmlist results * - silence = toggles private messages acceptance mode * - diet = toggles weight penalty mode * - tradeoff = toggles trade acceptance mode * - reload = reloads specified component from multisell|skill|npc|htm|item|instancemanager * - set/set_menu/set_mod = alters specified server setting * - saveolymp = saves olympiad state manually * - manualhero = cycles olympiad and calculate new heroes. * @version $Revision: 1.3.2.1.2.4 $ $Date: 2007/07/28 10:06:06 $ */ public class AdminAdmin implements IAdminCommandHandler { private static Logger _log = Logger.getLogger(AdminAdmin.class.getName()); private static final String[] ADMIN_COMMANDS = { "admin_admin", "admin_admin1", "admin_admin2", "admin_admin3", "admin_admin4", "admin_admin5", "admin_admin6", "admin_admin7", "admin_admin8", "admin_gmliston", "admin_gmlistoff", "admin_silence", "admin_diet", "admin_tradeoff", "admin_reload", "admin_set", "admin_set_mod", "admin_saveolymp", "admin_manualhero", "admin_sethero", "admin_endolympiad", "admin_setconfig", "admin_config_server", "admin_gmon" }; @Override public boolean useAdminCommand(String command, L2PcInstance activeChar) { if (command.startsWith("admin_admin")) { showMainPage(activeChar, command); } else if (command.equals("admin_config_server")) { showConfigPage(activeChar); } else if (command.startsWith("admin_gmliston")) { GmListTable.getInstance().showGm(activeChar); activeChar.sendMessage("Registered into gm list"); AdminHelpPage.showHelpPage(activeChar,"gm_menu.htm"); } else if (command.startsWith("admin_gmlistoff")) { GmListTable.getInstance().hideGm(activeChar); activeChar.sendMessage("Removed from gm list"); AdminHelpPage.showHelpPage(activeChar,"gm_menu.htm"); } else if (command.startsWith("admin_silence")) { if (activeChar.isSilenceMode()) // already in message refusal mode { activeChar.setSilenceMode(false); activeChar.sendPacket(SystemMessageId.MESSAGE_ACCEPTANCE_MODE); } else { activeChar.setSilenceMode(true); activeChar.sendPacket(SystemMessageId.MESSAGE_REFUSAL_MODE); } AdminHelpPage.showHelpPage(activeChar,"gm_menu.htm"); } else if (command.startsWith("admin_saveolymp")) { Olympiad.getInstance().saveOlympiadStatus(); activeChar.sendMessage("olympiad system saved."); } else if (command.startsWith("admin_endolympiad")) { try { Olympiad.getInstance().manualSelectHeroes(); } catch (Exception e) { _log.warning("An error occured while ending olympiad: " + e); } activeChar.sendMessage("Heroes formed"); } else if (command.startsWith("admin_manualhero") || command.startsWith("admin_sethero")) { L2PcInstance target = null; if (activeChar.getTarget() instanceof L2PcInstance) { target = (L2PcInstance) activeChar.getTarget(); target.setHero(target.isHero() ? false : true); } else { target = activeChar; target.setHero(target.isHero() ? false : true); } target.broadcastUserInfo(); } else if (command.startsWith("admin_diet")) { try { StringTokenizer st = new StringTokenizer(command); st.nextToken(); if (st.nextToken().equalsIgnoreCase("on")) { activeChar.setDietMode(true); activeChar.sendMessage("Diet mode on"); } else if (st.nextToken().equalsIgnoreCase("off")) { activeChar.setDietMode(false); activeChar.sendMessage("Diet mode off"); } } catch (Exception ex) { if (activeChar.getDietMode()) { activeChar.setDietMode(false); activeChar.sendMessage("Diet mode off"); } else { activeChar.setDietMode(true); activeChar.sendMessage("Diet mode on"); } } finally { activeChar.refreshOverloaded(); } AdminHelpPage.showHelpPage(activeChar,"gm_menu.htm"); } else if (command.startsWith("admin_tradeoff")) { try { String mode = command.substring(15); if (mode.equalsIgnoreCase("on")) { activeChar.setTradeRefusal(true); activeChar.sendMessage("Trade refusal enabled"); } else if (mode.equalsIgnoreCase("off")) { activeChar.setTradeRefusal(false); activeChar.sendMessage("Trade refusal disabled"); } } catch (Exception ex) { if (activeChar.getTradeRefusal()) { activeChar.setTradeRefusal(false); activeChar.sendMessage("Trade refusal disabled"); } else { activeChar.setTradeRefusal(true); activeChar.sendMessage("Trade refusal enabled"); } } AdminHelpPage.showHelpPage(activeChar,"gm_menu.htm"); } else if (command.startsWith("admin_reload")) { StringTokenizer st = new StringTokenizer(command); st.nextToken(); String type = ""; try { type = st.nextToken(); if (type.equals("multisell")) { MultiSell.getInstance().reload(); activeChar.sendMessage("All Multisells have been reloaded"); } else if (type.startsWith("teleport")) { TeleportLocationTable.getInstance().reloadAll(); activeChar.sendMessage("Teleport Locations have been reloaded"); } else if (type.startsWith("skill")) { SkillTable.getInstance().reload(); activeChar.sendMessage("All Skills have been reloaded"); } else if (type.startsWith("npcId")) { Integer npcId = Integer.parseInt(st.nextToken()); if (npcId != null) { NpcTable.getInstance().reloadNpc(npcId); for (L2Spawn spawn : SpawnTable.getInstance().getSpawnTable()) if (spawn != null && spawn.getNpcid() == npcId) spawn.respawnNpc(spawn.getLastSpawn()); activeChar.sendMessage("NPC " + npcId + " have been reloaded"); } } else if (type.equals("npc")) { NpcTable.getInstance().reloadAllNpc(); QuestManager.getInstance().reloadAllQuests(); activeChar.sendMessage("All NPCs have been reloaded"); } else if (type.startsWith("htm")) { HtmCache.getInstance().reload(); activeChar.sendMessage("Cache[HTML]: " + HtmCache.getInstance().getMemoryUsage() + " megabytes on " + HtmCache.getInstance().getLoadedFiles() + " files loaded"); } else if (type.startsWith("item")) { ItemTable.getInstance().reload(); activeChar.sendMessage("Item Templates have been reloaded"); } else if (type.startsWith("config")) { Config.load(); activeChar.sendMessage("All Config Settings have been reloaded"); } else if (type.startsWith("instancemanager")) { Manager.reloadAll(); activeChar.sendMessage("All Instance Manager has been reloaded"); } else if (type.startsWith("npcwalkers")) { NpcWalkerRoutesTable.getInstance().load(); activeChar.sendMessage("NPC Walker Routes have been reloaded"); } else if (type.startsWith("access")) { AccessLevels.getInstance().reloadAccessLevels(); AdminCommandAccessRights.getInstance().reloadAdminCommandAccessRights(); activeChar.sendMessage("Access Rights have been reloaded"); } else if (type.startsWith("quests")) { QuestManager.getInstance().reloadAllQuests(); activeChar.sendMessage("All Quests have been reloaded"); } else if (type.startsWith("door")) { DoorTable.getInstance().reloadAll(); activeChar.sendMessage("All Doors have been reloaded"); } activeChar.sendMessage("WARNING: There are several known issues regarding this feature. Reloading server data during runtime is STRONGLY NOT RECOMMENDED for live servers, just for developing environments."); } catch (Exception e) { activeChar.sendMessage("An error occured while reloading " + type + " !"); activeChar.sendMessage("Usage: //reload "); _log.warning("An error occured while reloading " + type + ": " + e); //do not mask an exception here } } else if (command.startsWith("admin_setconfig")) { StringTokenizer st = new StringTokenizer(command); st.nextToken(); try { String pName = st.nextToken(); String pValue = st.nextToken(); if (Config.setParameterValue(pName, pValue)) activeChar.sendMessage("Config parameter " + pName + " set to " + pValue); else activeChar.sendMessage("Invalid parameter!"); } catch (Exception e) { activeChar.sendMessage("Usage: //setconfig "); } finally { showConfigPage(activeChar); } } else if (command.startsWith("admin_set")) { StringTokenizer st = new StringTokenizer(command); String[] cmd = st.nextToken().split("_"); try { String[] parameter = st.nextToken().split("="); String pName = parameter[0].trim(); String pValue = parameter[1].trim(); if (Config.setParameterValue(pName, pValue)) activeChar.sendMessage("parameter " + pName + " succesfully set to " + pValue); else activeChar.sendMessage("Invalid parameter!"); } catch (Exception e) { if (cmd.length == 2) activeChar.sendMessage("Usage: //set parameter=value"); } finally { if (cmd.length == 3) { if (cmd[2].equalsIgnoreCase("mod")) AdminHelpPage.showHelpPage(activeChar, "mods_menu.htm"); } } } else if (command.startsWith("admin_gmon")) { // nothing } return true; } @Override public String[] getAdminCommandList() { return ADMIN_COMMANDS; } private void showMainPage(L2PcInstance activeChar, String command) { int mode = 0; String filename = null; try { mode = Integer.parseInt(command.substring(11)); } catch (Exception e) { } switch (mode) { case 1: filename = "main"; break; case 2: filename = "game"; break; case 3: filename = "effects"; break; case 4: filename = "server"; break; case 5: filename = "mods"; break; case 6: filename = "char"; break; case 7: filename = "gm"; break; case 8: filename = "old"; break; default: if (Config.GM_ADMIN_MENU_STYLE.equals("modern")) filename = "main"; else filename = "classic"; break; } AdminHelpPage.showHelpPage(activeChar, filename + "_menu.htm"); } public void showConfigPage(L2PcInstance activeChar) { NpcHtmlMessage adminReply = new NpcHtmlMessage(5); TextBuilder replyMSG = new TextBuilder("L2J :: Config"); replyMSG.append("
Config Server Panel

"); replyMSG.append("
"); replyMSG.append(""); replyMSG.append(""); replyMSG.append(""); replyMSG.append(""); replyMSG.append(""); replyMSG.append(""); replyMSG.append(""); replyMSG.append(""); replyMSG.append(""); replyMSG.append(""); replyMSG.append("
Drop:
Rate EXP = " + Config.RATE_XP + "
Rate SP = " + Config.RATE_SP + "
Rate Drop Spoil = " + Config.RATE_DROP_SPOIL + "
Enchant:
Enchant Element Stone = " + Config.ENCHANT_CHANCE_ELEMENT_STONE + "
Enchant Element Crystal = " + Config.ENCHANT_CHANCE_ELEMENT_CRYSTAL + "
Enchant Element Jewel = " + Config.ENCHANT_CHANCE_ELEMENT_JEWEL + "
Enchant Element Energy = " + Config.ENCHANT_CHANCE_ELEMENT_ENERGY + "
"); adminReply.setHtml(replyMSG.toString()); activeChar.sendPacket(adminReply); } }