AdminReload.java 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  1. /*
  2. * Copyright (C) 2004-2013 L2J DataPack
  3. *
  4. * This file is part of L2J DataPack.
  5. *
  6. * L2J DataPack is free software: you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation, either version 3 of the License, or
  9. * (at your option) any later version.
  10. *
  11. * L2J DataPack is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  18. */
  19. package handlers.admincommandhandlers;
  20. import java.io.File;
  21. import java.util.StringTokenizer;
  22. import javax.script.ScriptException;
  23. import com.l2jserver.Config;
  24. import com.l2jserver.gameserver.cache.HtmCache;
  25. import com.l2jserver.gameserver.datatables.AdminTable;
  26. import com.l2jserver.gameserver.datatables.BuyListData;
  27. import com.l2jserver.gameserver.datatables.CrestTable;
  28. import com.l2jserver.gameserver.datatables.DoorTable;
  29. import com.l2jserver.gameserver.datatables.EnchantItemData;
  30. import com.l2jserver.gameserver.datatables.EnchantItemGroupsData;
  31. import com.l2jserver.gameserver.datatables.ItemTable;
  32. import com.l2jserver.gameserver.datatables.MultisellData;
  33. import com.l2jserver.gameserver.datatables.NpcTable;
  34. import com.l2jserver.gameserver.datatables.SkillTable;
  35. import com.l2jserver.gameserver.datatables.TeleportLocationTable;
  36. import com.l2jserver.gameserver.datatables.TransformData;
  37. import com.l2jserver.gameserver.handler.IAdminCommandHandler;
  38. import com.l2jserver.gameserver.instancemanager.CursedWeaponsManager;
  39. import com.l2jserver.gameserver.instancemanager.QuestManager;
  40. import com.l2jserver.gameserver.instancemanager.WalkingManager;
  41. import com.l2jserver.gameserver.instancemanager.ZoneManager;
  42. import com.l2jserver.gameserver.model.actor.instance.L2PcInstance;
  43. import com.l2jserver.gameserver.scripting.L2ScriptEngineManager;
  44. import com.l2jserver.gameserver.util.Util;
  45. /**
  46. * @author Nos
  47. */
  48. public class AdminReload implements IAdminCommandHandler
  49. {
  50. private static final String[] ADMIN_COMMANDS =
  51. {
  52. "admin_reload"
  53. };
  54. @Override
  55. public boolean useAdminCommand(String command, L2PcInstance activeChar)
  56. {
  57. final StringTokenizer st = new StringTokenizer(command, " ");
  58. final String actualCommand = st.nextToken();
  59. if (actualCommand.equalsIgnoreCase("admin_reload"))
  60. {
  61. if (!st.hasMoreTokens())
  62. {
  63. AdminHtml.showAdminHtml(activeChar, "reload.htm");
  64. activeChar.sendMessage("Usage: //reload <config|access|npc [npc_id]|quest [quest_id|quest_name]|walker|htm[l] [file|directory]|multisell|buylist|teleport|skill|item|door|effect|handler|enchant>");
  65. return true;
  66. }
  67. final String type = st.nextToken();
  68. switch (type.toLowerCase())
  69. {
  70. case "config":
  71. {
  72. Config.load();
  73. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Configs.");
  74. break;
  75. }
  76. case "access":
  77. {
  78. AdminTable.getInstance().load();
  79. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Access.");
  80. break;
  81. }
  82. case "npc":
  83. {
  84. if (st.hasMoreElements())
  85. {
  86. try
  87. {
  88. final int npcId = Integer.parseInt(st.nextToken());
  89. NpcTable.getInstance().reloadNpc(npcId, true, true, true, true, true, true);
  90. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded NPC ID:" + npcId + ".");
  91. }
  92. catch (NumberFormatException e)
  93. {
  94. activeChar.sendMessage("Usage: //reload npc <npc_id>");
  95. return false;
  96. }
  97. }
  98. else
  99. {
  100. NpcTable.getInstance().reloadAllNpc();
  101. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Npcs.");
  102. }
  103. break;
  104. }
  105. case "quest":
  106. {
  107. if (st.hasMoreElements())
  108. {
  109. String value = st.nextToken();
  110. if (!Util.isDigit(value))
  111. {
  112. QuestManager.getInstance().reload(value);
  113. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Quest Name:" + value + ".");
  114. }
  115. else
  116. {
  117. final int questId = Integer.parseInt(value);
  118. QuestManager.getInstance().reload(questId);
  119. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Quest ID:" + questId + ".");
  120. }
  121. }
  122. else
  123. {
  124. QuestManager.getInstance().reloadAllQuests();
  125. activeChar.sendMessage("All Quests have been reloaded.");
  126. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Quests.");
  127. }
  128. break;
  129. }
  130. case "walker":
  131. {
  132. WalkingManager.getInstance().load();
  133. activeChar.sendMessage("All Walkers have been reloaded");
  134. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Walkers.");
  135. break;
  136. }
  137. case "htm":
  138. case "html":
  139. {
  140. if (st.hasMoreElements())
  141. {
  142. final String path = st.nextToken();
  143. final File file = new File(Config.DATAPACK_ROOT, "data/html/" + path);
  144. if (file.exists())
  145. {
  146. HtmCache.getInstance().reload(file);
  147. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Htm File:" + file.getName() + ".");
  148. }
  149. else
  150. {
  151. activeChar.sendMessage("File or Directory does not exist.");
  152. }
  153. }
  154. else
  155. {
  156. HtmCache.getInstance().reload();
  157. activeChar.sendMessage("Cache[HTML]: " + HtmCache.getInstance().getMemoryUsage() + " megabytes on " + HtmCache.getInstance().getLoadedFiles() + " files loaded");
  158. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Htms.");
  159. }
  160. break;
  161. }
  162. case "multisell":
  163. {
  164. MultisellData.getInstance().load();
  165. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Multisells.");
  166. break;
  167. }
  168. case "buylist":
  169. {
  170. BuyListData.getInstance().load();
  171. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Buylists.");
  172. break;
  173. }
  174. case "teleport":
  175. {
  176. TeleportLocationTable.getInstance().reloadAll();
  177. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Teleports.");
  178. break;
  179. }
  180. case "skill":
  181. {
  182. SkillTable.getInstance().reload();
  183. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Skills.");
  184. break;
  185. }
  186. case "item":
  187. {
  188. ItemTable.getInstance().reload();
  189. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Items.");
  190. break;
  191. }
  192. case "door":
  193. {
  194. DoorTable.getInstance().load();
  195. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Doors.");
  196. break;
  197. }
  198. case "zone":
  199. {
  200. ZoneManager.getInstance().reload();
  201. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Zones.");
  202. break;
  203. }
  204. case "cw":
  205. {
  206. CursedWeaponsManager.getInstance().reload();
  207. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Cursed Weapons.");
  208. break;
  209. }
  210. case "crest":
  211. {
  212. CrestTable.getInstance().load();
  213. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Crests.");
  214. break;
  215. }
  216. case "effect":
  217. {
  218. final File file = new File(L2ScriptEngineManager.SCRIPT_FOLDER, "handlers/EffectMasterHandler.java");
  219. try
  220. {
  221. L2ScriptEngineManager.getInstance().executeScript(file);
  222. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Effects.");
  223. }
  224. catch (ScriptException e)
  225. {
  226. L2ScriptEngineManager.getInstance().reportScriptFileError(file, e);
  227. activeChar.sendMessage("There was an error while loading handlers.");
  228. }
  229. break;
  230. }
  231. case "handler":
  232. {
  233. final File file = new File(L2ScriptEngineManager.SCRIPT_FOLDER, "handlers/MasterHandler.java");
  234. try
  235. {
  236. L2ScriptEngineManager.getInstance().executeScript(file);
  237. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded Handlers.");
  238. }
  239. catch (ScriptException e)
  240. {
  241. L2ScriptEngineManager.getInstance().reportScriptFileError(file, e);
  242. activeChar.sendMessage("There was an error while loading handlers.");
  243. }
  244. break;
  245. }
  246. case "enchant":
  247. {
  248. EnchantItemGroupsData.getInstance().load();
  249. EnchantItemData.getInstance().load();
  250. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded item enchanting data.");
  251. break;
  252. }
  253. case "transform":
  254. {
  255. TransformData.getInstance().load();
  256. AdminTable.getInstance().broadcastMessageToGMs(activeChar.getName() + ": Reloaded transform data.");
  257. break;
  258. }
  259. default:
  260. {
  261. activeChar.sendMessage("Usage: //reload <config|access|npc [npc_id]|quest [quest_id|quest_name]|walker|htm[l] [file|directory]|multisell|buylist|teleport|skill|item|door|effect|handler>");
  262. return true;
  263. }
  264. }
  265. 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.");
  266. }
  267. return true;
  268. }
  269. @Override
  270. public String[] getAdminCommandList()
  271. {
  272. return ADMIN_COMMANDS;
  273. }
  274. }