/* * Copyright (C) 2004-2013 L2J DataPack * * This file is part of L2J DataPack. * * L2J DataPack 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. * * L2J DataPack 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.Level; import java.util.logging.Logger; import javolution.text.TextBuilder; import com.l2jserver.Config; import com.l2jserver.gameserver.cache.HtmCache; import com.l2jserver.gameserver.datatables.AdminTable; import com.l2jserver.gameserver.datatables.DoorTable; import com.l2jserver.gameserver.datatables.ItemTable; import com.l2jserver.gameserver.datatables.MultisellData; import com.l2jserver.gameserver.datatables.NpcTable; 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.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 - 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 final 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_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")) { AdminTable.getInstance().showGm(activeChar); activeChar.sendMessage("Registered into gm list"); AdminHelpPage.showHelpPage(activeChar, "gm_menu.htm"); } else if (command.startsWith("admin_gmlistoff")) { AdminTable.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")) { if (activeChar.getTarget() == null) { activeChar.sendPacket(SystemMessageId.INCORRECT_TARGET); return false; } final L2PcInstance target = activeChar.getTarget().isPlayer() ? activeChar.getTarget().getActingPlayer() : activeChar; target.setHero(!target.isHero()); 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(); if (!st.hasMoreTokens()) { activeChar.sendMessage("You need to specify a type to reload!"); activeChar.sendMessage("Usage: //reload "); return false; } final String type = st.nextToken(); try { if (type.equals("multisell")) { MultisellData.getInstance().load(); 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().getSpawns(npcId)) { if (spawn != null) { 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("access")) { AdminTable.getInstance().load(); 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().load(); 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.log(Level.WARNING, "An error occured while reloading " + type + ": " + e, e); } } 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; default: filename = "main"; 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); } }