123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338 |
- /*
- * Copyright (C) 2004-2014 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 <http://www.gnu.org/licenses/>.
- */
- package handlers.admincommandhandlers;
- import java.io.File;
- import java.util.List;
- import java.util.Set;
- import java.util.TreeSet;
- import javax.script.ScriptException;
- import com.l2jserver.gameserver.handler.IAdminCommandHandler;
- import com.l2jserver.gameserver.instancemanager.QuestManager;
- import com.l2jserver.gameserver.model.actor.L2Character;
- import com.l2jserver.gameserver.model.actor.instance.L2PcInstance;
- import com.l2jserver.gameserver.model.events.EventType;
- import com.l2jserver.gameserver.model.events.ListenerRegisterType;
- import com.l2jserver.gameserver.model.events.listeners.AbstractEventListener;
- import com.l2jserver.gameserver.model.quest.Quest;
- import com.l2jserver.gameserver.model.quest.QuestTimer;
- import com.l2jserver.gameserver.network.serverpackets.NpcHtmlMessage;
- import com.l2jserver.gameserver.scripting.L2ScriptEngineManager;
- import com.l2jserver.gameserver.util.Util;
- public class AdminQuest implements IAdminCommandHandler
- {
- private static final String[] ADMIN_COMMANDS =
- {
- "admin_quest_reload",
- "admin_script_load",
- "admin_script_unload",
- "admin_show_quests",
- "admin_quest_info"
- };
-
- @Override
- public boolean useAdminCommand(String command, L2PcInstance activeChar)
- {
- if (activeChar == null)
- {
- return false;
- }
-
- // syntax will either be:
- // //quest_reload <id>
- // //quest_reload <questName>
- // The questName MUST start with a non-numeric character for this to work,
- // regardless which of the two formats is used.
- // Example: //quest_reload orc_occupation_change_1
- // Example: //quest_reload chests
- // Example: //quest_reload SagasSuperclass
- // Example: //quest_reload 12
- if (command.startsWith("admin_quest_reload"))
- {
- String[] parts = command.split(" ");
- if (parts.length < 2)
- {
- activeChar.sendMessage("Usage: //quest_reload <questFolder>.<questSubFolders...>.questName> or //quest_reload <id>");
- }
- else
- {
- // try the first param as id
- try
- {
- int questId = Integer.parseInt(parts[1]);
- if (QuestManager.getInstance().reload(questId))
- {
- activeChar.sendMessage("Quest Reloaded Successfully.");
- }
- else
- {
- activeChar.sendMessage("Quest Reloaded Failed");
- }
- }
- catch (NumberFormatException e)
- {
- if (QuestManager.getInstance().reload(parts[1]))
- {
- activeChar.sendMessage("Quest Reloaded Successfully.");
- }
- else
- {
- activeChar.sendMessage("Quest Reloaded Failed");
- }
- }
- }
- }
- // script load should NOT be used in place of reload. If a script is already loaded
- // successfully, quest_reload ought to be used. The script_load command should only
- // be used for scripts that failed to load altogether (eg. due to errors) or that
- // did not at all exist during server boot. Using script_load to re-load a previously
- // loaded script may cause unpredictable script flow, minor loss of data, and more.
- // This provides a way to load new scripts without having to reboot the server.
- else if (command.startsWith("admin_script_load"))
- {
- String[] parts = command.split(" ");
- if (parts.length < 2)
- {
- // activeChar.sendMessage("Example: //script_load <questFolder>/<questSubFolders...>/<filename>.<ext> ");
- activeChar.sendMessage("Example: //script_load quests/SagasSuperclass/__init__.py");
- }
- else
- {
- File file = new File(L2ScriptEngineManager.SCRIPT_FOLDER, parts[1]);
- // Trying to reload by script name.
- if (!file.exists())
- {
- Quest quest = QuestManager.getInstance().getQuest(parts[1]);
- if (quest != null)
- {
- file = new File(L2ScriptEngineManager.SCRIPT_FOLDER, quest.getClass().getName().replaceAll("\\.", "/") + ".java");
- }
- }
-
- // Reloading by full path
- if (file.isFile())
- {
- try
- {
- L2ScriptEngineManager.getInstance().executeScript(file);
-
- // This part should be called only when the script is successfully loaded.
- activeChar.sendMessage("Script Successfully Loaded.");
- }
- catch (ScriptException e)
- {
- activeChar.sendMessage("Failed loading: " + parts[1]);
- L2ScriptEngineManager.getInstance().reportScriptFileError(file, e);
- }
- catch (Exception e)
- {
- activeChar.sendMessage("Failed loading: " + parts[1]);
- }
- }
- else
- {
- activeChar.sendMessage("File Not Found: " + parts[1]);
- }
- }
-
- }
- else if (command.startsWith("admin_script_unload"))
- {
- String[] parts = command.split(" ");
- if (parts.length < 2)
- {
- activeChar.sendMessage("Example: //script_unload questName/questId");
- }
- else
- {
- Quest q = Util.isDigit(parts[1]) ? QuestManager.getInstance().getQuest(Integer.parseInt(parts[1])) : QuestManager.getInstance().getQuest(parts[1]);
-
- if (q != null)
- {
- if (q.unload())
- {
- activeChar.sendMessage("Script Successfully Unloaded [" + q.getName() + "/" + q.getId() + "]");
- }
- else
- {
- activeChar.sendMessage("Failed unloading [" + q.getName() + "/" + q.getId() + "].");
- }
- }
- else
- {
- activeChar.sendMessage("The quest [" + parts[1] + "] was not found!.");
- }
- }
- }
- else if (command.startsWith("admin_show_quests"))
- {
- if (activeChar.getTarget() == null)
- {
- activeChar.sendMessage("Get a target first.");
- }
- else if (!activeChar.getTarget().isCharacter())
- {
- activeChar.sendMessage("Invalid Target.");
- }
- else
- {
- final L2Character character = (L2Character) activeChar.getTarget();
- final StringBuilder sb = new StringBuilder();
- final Set<String> questNames = new TreeSet<>();
- for (EventType type : EventType.values())
- {
- for (AbstractEventListener listener : character.getListeners(type))
- {
- if (listener.getOwner() instanceof Quest)
- {
- final Quest quest = (Quest) listener.getOwner();
- if (questNames.contains(quest.getName()))
- {
- continue;
- }
- sb.append("<tr><td colspan=\"4\"><font color=\"LEVEL\"><a action=\"bypass -h admin_quest_info " + quest.getName() + "\">" + quest.getName() + "</a></font></td></tr>");
- questNames.add(quest.getName());
- }
- }
- }
-
- final NpcHtmlMessage msg = new NpcHtmlMessage(0, 1);
- msg.setFile(activeChar.getHtmlPrefix(), "data/html/admin/npc-quests.htm");
- msg.replace("%quests%", sb.toString());
- msg.replace("%objid%", character.getObjectId());
- msg.replace("%questName%", "");
- activeChar.sendPacket(msg);
- }
- }
- else if (command.startsWith("admin_quest_info "))
- {
- final String questName = command.substring("admin_quest_info ".length());
- final Quest quest = QuestManager.getInstance().getQuest(questName);
- String events = "", npcs = "", items = "", timers = "";
- int counter = 0;
- if (quest == null)
- {
- activeChar.sendMessage("Couldn't find quest or script with name " + questName + " !");
- return false;
- }
-
- final Set<EventType> listenerTypes = new TreeSet<>();
- for (AbstractEventListener listener : quest.getListeners())
- {
- if (!listenerTypes.contains(listener.getType()))
- {
- events += ", " + listener.getType().name();
- listenerTypes.add(listener.getType());
- counter++;
- }
- if (counter > 10)
- {
- counter = 0;
- break;
- }
- }
-
- final Set<Integer> npcIds = new TreeSet<>(quest.getRegisteredIds(ListenerRegisterType.NPC));
- for (int npcId : npcIds)
- {
- npcs += ", " + npcId;
- counter++;
- if (counter > 50)
- {
- counter = 0;
- break;
- }
- }
-
- if (!events.isEmpty())
- {
- events = listenerTypes.size() + ": " + events.substring(2);
- }
-
- if (!npcs.isEmpty())
- {
- npcs = npcIds.size() + ": " + npcs.substring(2);
- }
-
- if (quest.getRegisteredItemIds() != null)
- {
- for (int itemId : quest.getRegisteredItemIds())
- {
- items += ", " + itemId;
- counter++;
- if (counter > 20)
- {
- counter = 0;
- break;
- }
- }
- items = quest.getRegisteredItemIds().length + ":" + items.substring(2);
- }
-
- for (List<QuestTimer> list : quest.getQuestTimers().values())
- {
- for (QuestTimer timer : list)
- {
- timers += "<tr><td colspan=\"4\"><table width=270 border=0 bgcolor=131210><tr><td width=270><font color=\"LEVEL\">" + timer.getName() + ":</font> <font color=00FF00>Active: " + timer.getIsActive() + " Repeatable: " + timer.getIsRepeating() + " Player: " + timer.getPlayer() + " Npc: " + timer.getNpc() + "</font></td></tr></table></td></tr>";
- counter++;
- if (counter > 10)
- {
- break;
- }
- }
- }
-
- final StringBuilder sb = new StringBuilder();
- sb.append("<tr><td colspan=\"4\"><table width=270 border=0 bgcolor=131210><tr><td width=270><font color=\"LEVEL\">ID:</font> <font color=00FF00>" + quest.getId() + "</font></td></tr></table></td></tr>");
- sb.append("<tr><td colspan=\"4\"><table width=270 border=0 bgcolor=131210><tr><td width=270><font color=\"LEVEL\">Name:</font> <font color=00FF00>" + quest.getName() + "</font></td></tr></table></td></tr>");
- sb.append("<tr><td colspan=\"4\"><table width=270 border=0 bgcolor=131210><tr><td width=270><font color=\"LEVEL\">Descr:</font> <font color=00FF00>" + quest.getDescr() + "</font></td></tr></table></td></tr>");
- sb.append("<tr><td colspan=\"4\"><table width=270 border=0 bgcolor=131210><tr><td width=270><font color=\"LEVEL\">Path:</font> <font color=00FF00>" + quest.getClass().getName().substring(0, quest.getClass().getName().lastIndexOf('.')).replaceAll("\\.", "/") + "</font></td></tr></table></td></tr>");
- sb.append("<tr><td colspan=\"4\"><table width=270 border=0 bgcolor=131210><tr><td width=270><font color=\"LEVEL\">Events:</font> <font color=00FF00>" + events + "</font></td></tr></table></td></tr>");
- if (!npcs.isEmpty())
- {
- sb.append("<tr><td colspan=\"4\"><table width=270 border=0 bgcolor=131210><tr><td width=270><font color=\"LEVEL\">NPCs:</font> <font color=00FF00>" + npcs + "</font></td></tr></table></td></tr>");
- }
- if (!items.isEmpty())
- {
- sb.append("<tr><td colspan=\"4\"><table width=270 border=0 bgcolor=131210><tr><td width=270><font color=\"LEVEL\">Items:</font> <font color=00FF00>" + items + "</font></td></tr></table></td></tr>");
- }
- if (!timers.isEmpty())
- {
- sb.append("<tr><td colspan=\"4\"><table width=270 border=0 bgcolor=131210><tr><td width=270><font color=\"LEVEL\">Timers:</font> <font color=00FF00></font></td></tr></table></td></tr>");
- sb.append(timers);
- }
-
- final NpcHtmlMessage msg = new NpcHtmlMessage(0, 1);
- msg.setFile(activeChar.getHtmlPrefix(), "data/html/admin/npc-quests.htm");
- msg.replace("%quests%", sb.toString());
- msg.replace("%questName%", "<table><tr><td width=\"50\" align=\"left\"><a action=\"bypass -h admin_script_load " + quest.getName() + "\">Reload</a></td> <td width=\"150\" align=\"center\"><a action=\"bypass -h admin_quest_info " + quest.getName() + "\">" + quest.getName() + "</a></td> <td width=\"50\" align=\"right\"><a action=\"bypass -h admin_script_unload " + quest.getName() + "\">Unload</a></tr></td></table>");
- activeChar.sendPacket(msg);
- }
- return true;
- }
-
- @Override
- public String[] getAdminCommandList()
- {
- return ADMIN_COMMANDS;
- }
- }
|