AdminSpawn.java 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442
  1. /*
  2. * This program is free software: you can redistribute it and/or modify it under
  3. * the terms of the GNU General Public License as published by the Free Software
  4. * Foundation, either version 3 of the License, or (at your option) any later
  5. * version.
  6. *
  7. * This program is distributed in the hope that it will be useful, but WITHOUT
  8. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
  9. * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
  10. * details.
  11. *
  12. * You should have received a copy of the GNU General Public License along with
  13. * this program. If not, see <http://www.gnu.org/licenses/>.
  14. */
  15. package handlers.admincommandhandlers;
  16. import java.util.NoSuchElementException;
  17. import java.util.StringTokenizer;
  18. import java.util.logging.Logger;
  19. import java.util.regex.Matcher;
  20. import java.util.regex.Pattern;
  21. import com.l2jserver.Config;
  22. import com.l2jserver.gameserver.GmListTable;
  23. import com.l2jserver.gameserver.SevenSigns;
  24. import com.l2jserver.gameserver.datatables.NpcTable;
  25. import com.l2jserver.gameserver.datatables.SpawnTable;
  26. import com.l2jserver.gameserver.datatables.TeleportLocationTable;
  27. import com.l2jserver.gameserver.handler.IAdminCommandHandler;
  28. import com.l2jserver.gameserver.instancemanager.DayNightSpawnManager;
  29. import com.l2jserver.gameserver.instancemanager.InstanceManager;
  30. import com.l2jserver.gameserver.instancemanager.QuestManager;
  31. import com.l2jserver.gameserver.instancemanager.RaidBossSpawnManager;
  32. import com.l2jserver.gameserver.model.AutoChatHandler;
  33. import com.l2jserver.gameserver.model.AutoSpawnHandler;
  34. import com.l2jserver.gameserver.model.L2Object;
  35. import com.l2jserver.gameserver.model.L2Spawn;
  36. import com.l2jserver.gameserver.model.L2World;
  37. import com.l2jserver.gameserver.model.actor.L2Npc;
  38. import com.l2jserver.gameserver.model.actor.instance.L2PcInstance;
  39. import com.l2jserver.gameserver.model.entity.Instance;
  40. import com.l2jserver.gameserver.network.SystemMessageId;
  41. import com.l2jserver.gameserver.network.serverpackets.NpcHtmlMessage;
  42. import com.l2jserver.gameserver.network.serverpackets.SystemMessage;
  43. import com.l2jserver.gameserver.templates.chars.L2NpcTemplate;
  44. import com.l2jserver.gameserver.util.Broadcast;
  45. import com.l2jserver.util.StringUtil;
  46. /**
  47. * This class handles following admin commands: - show_spawns = shows menu -
  48. * spawn_index lvl = shows menu for monsters with respective level -
  49. * spawn_monster id = spawns monster id on target
  50. *
  51. * @version $Revision: 1.2.2.5.2.5 $ $Date: 2005/04/11 10:06:06 $
  52. */
  53. public class AdminSpawn implements IAdminCommandHandler
  54. {
  55. private static final String[] ADMIN_COMMANDS =
  56. {
  57. "admin_show_spawns",
  58. "admin_spawn",
  59. "admin_spawn_monster",
  60. "admin_spawn_index",
  61. "admin_unspawnall",
  62. "admin_respawnall",
  63. "admin_spawn_reload",
  64. "admin_npc_index",
  65. "admin_spawn_once",
  66. "admin_show_npcs",
  67. "admin_teleport_reload",
  68. "admin_spawnnight",
  69. "admin_spawnday",
  70. "admin_instance_spawns",
  71. "admin_list_spawns",
  72. "admin_list_positions",
  73. "admin_spawn_debug_menu",
  74. "admin_spawn_debug_print",
  75. "admin_spawn_debug_print_menu"
  76. };
  77. public static Logger _log = Logger.getLogger(AdminSpawn.class.getName());
  78. public boolean useAdminCommand(String command, L2PcInstance activeChar)
  79. {
  80. if (command.equals("admin_show_spawns"))
  81. {
  82. AdminHelpPage.showHelpPage(activeChar, "spawns.htm");
  83. }
  84. else if (command.equalsIgnoreCase("admin_spawn_debug_menu"))
  85. {
  86. AdminHelpPage.showHelpPage(activeChar, "spawns_debug.htm");
  87. }
  88. else if (command.startsWith("admin_spawn_debug_print"))
  89. {
  90. StringTokenizer st = new StringTokenizer(command, " ");
  91. L2Object target = activeChar.getTarget();
  92. if(target instanceof L2Npc)
  93. {
  94. try
  95. {
  96. st.nextToken();
  97. int type = Integer.parseInt(st.nextToken());
  98. printSpawn((L2Npc) target, type);
  99. if(command.contains("_menu"))
  100. AdminHelpPage.showHelpPage(activeChar, "spawns_debug.htm");
  101. }
  102. catch (Exception e)
  103. {
  104. }
  105. }
  106. else
  107. activeChar.sendPacket(SystemMessageId.INCORRECT_TARGET);
  108. }
  109. else if (command.startsWith("admin_spawn_index"))
  110. {
  111. StringTokenizer st = new StringTokenizer(command, " ");
  112. try
  113. {
  114. st.nextToken();
  115. int level = Integer.parseInt(st.nextToken());
  116. int from = 0;
  117. try
  118. {
  119. from = Integer.parseInt(st.nextToken());
  120. }
  121. catch (NoSuchElementException nsee)
  122. {
  123. }
  124. showMonsters(activeChar, level, from);
  125. }
  126. catch (Exception e)
  127. {
  128. AdminHelpPage.showHelpPage(activeChar, "spawns.htm");
  129. }
  130. }
  131. else if (command.equals("admin_show_npcs"))
  132. {
  133. AdminHelpPage.showHelpPage(activeChar, "npcs.htm");
  134. }
  135. else if (command.startsWith("admin_npc_index"))
  136. {
  137. StringTokenizer st = new StringTokenizer(command, " ");
  138. try
  139. {
  140. st.nextToken();
  141. String letter = st.nextToken();
  142. int from = 0;
  143. try
  144. {
  145. from = Integer.parseInt(st.nextToken());
  146. }
  147. catch (NoSuchElementException nsee)
  148. {
  149. }
  150. showNpcs(activeChar, letter, from);
  151. }
  152. catch (Exception e)
  153. {
  154. AdminHelpPage.showHelpPage(activeChar, "npcs.htm");
  155. }
  156. }
  157. else if (command.startsWith("admin_instance_spawns"))
  158. {
  159. StringTokenizer st = new StringTokenizer(command, " ");
  160. try
  161. {
  162. st.nextToken();
  163. int instance = Integer.parseInt(st.nextToken());
  164. if(instance >= 300000)
  165. {
  166. final StringBuilder html = StringUtil.startAppend(500 + 1000,
  167. "<html><table width=\"100%\"><tr><td width=45><button value=\"Main\" action=\"bypass -h admin_admin\" width=45 height=21 back=\"L2UI_ct1.button_df\" fore=\"L2UI_ct1.button_df\"></td><td width=180><center>",
  168. "<font color=\"LEVEL\">Spawns for "+String.valueOf(instance)+"</font>",
  169. "</td><td width=45><button value=\"Back\" action=\"bypass -h admin_current_player\" width=45 height=21 back=\"L2UI_ct1.button_df\" fore=\"L2UI_ct1.button_df\"></td></tr></table><br>",
  170. "<table width=\"100%\"><tr><td width=200>NpcName</td><td width=70>Action</td></tr>");
  171. int counter = 0;
  172. int skiped = 0;
  173. Instance inst = InstanceManager.getInstance().getInstance(instance);
  174. if(inst != null)
  175. {
  176. for(L2Npc npc : inst.getNpcs())
  177. {
  178. if(!npc.isDead())
  179. {
  180. // Only 50 because of client html limitation
  181. if(counter < 50)
  182. {
  183. StringUtil.append(html,"<tr><td>"+npc.getName()+"</td><td>",
  184. "<a action=\"bypass -h admin_move_to "+npc.getX()+" "+npc.getY()+" "+npc.getZ()+"\">Go</a>",
  185. "</td></tr>");
  186. counter++;
  187. }
  188. else
  189. skiped++;
  190. }
  191. }
  192. StringUtil.append(html, "<tr><td>Skipped:</td><td>"+String.valueOf(skiped)+"</td></tr></table></body></html>");
  193. NpcHtmlMessage ms = new NpcHtmlMessage(1);
  194. ms.setHtml(html.toString());
  195. activeChar.sendPacket(ms);
  196. }
  197. else
  198. activeChar.sendMessage("Cannot find instance "+instance);
  199. }
  200. else
  201. activeChar.sendMessage("Invalid instance number.");
  202. }
  203. catch (Exception e)
  204. {
  205. activeChar.sendMessage("Usage //instance_spawns <instance_number>");
  206. }
  207. }
  208. else if (command.startsWith("admin_unspawnall"))
  209. {
  210. Broadcast.toAllOnlinePlayers(SystemMessage.getSystemMessage(SystemMessageId.NPC_SERVER_NOT_OPERATING));
  211. RaidBossSpawnManager.getInstance().cleanUp();
  212. DayNightSpawnManager.getInstance().cleanUp();
  213. L2World.getInstance().deleteVisibleNpcSpawns();
  214. GmListTable.broadcastMessageToGMs("NPC Unspawn completed!");
  215. }
  216. else if (command.startsWith("admin_spawnday"))
  217. {
  218. DayNightSpawnManager.getInstance().spawnDayCreatures();
  219. }
  220. else if (command.startsWith("admin_spawnnight"))
  221. {
  222. DayNightSpawnManager.getInstance().spawnNightCreatures();
  223. }
  224. else if (command.startsWith("admin_respawnall") || command.startsWith("admin_spawn_reload"))
  225. {
  226. // make sure all spawns are deleted
  227. RaidBossSpawnManager.getInstance().cleanUp();
  228. DayNightSpawnManager.getInstance().cleanUp();
  229. L2World.getInstance().deleteVisibleNpcSpawns();
  230. // now respawn all
  231. NpcTable.getInstance().reloadAllNpc();
  232. SpawnTable.getInstance().reloadAll();
  233. RaidBossSpawnManager.getInstance().reloadBosses();
  234. AutoSpawnHandler.getInstance().reload();
  235. AutoChatHandler.getInstance().reload();
  236. SevenSigns.getInstance().spawnSevenSignsNPC();
  237. QuestManager.getInstance().reloadAllQuests();
  238. GmListTable.broadcastMessageToGMs("NPC Respawn completed!");
  239. }
  240. else if (command.startsWith("admin_teleport_reload"))
  241. {
  242. TeleportLocationTable.getInstance().reloadAll();
  243. GmListTable.broadcastMessageToGMs("Teleport List Table reloaded.");
  244. }
  245. else if (command.startsWith("admin_spawn_monster") || command.startsWith("admin_spawn"))
  246. {
  247. StringTokenizer st = new StringTokenizer(command, " ");
  248. try
  249. {
  250. String cmd = st.nextToken();
  251. String id = st.nextToken();
  252. int respawnTime = 0;
  253. int mobCount = 1;
  254. if (st.hasMoreTokens())
  255. mobCount = Integer.parseInt(st.nextToken());
  256. if (st.hasMoreTokens())
  257. respawnTime = Integer.parseInt(st.nextToken());
  258. if (cmd.equalsIgnoreCase("admin_spawn_once"))
  259. spawnMonster(activeChar, id, respawnTime, mobCount, false);
  260. else
  261. spawnMonster(activeChar, id, respawnTime, mobCount, true);
  262. }
  263. catch (Exception e)
  264. { // Case of wrong or missing monster data
  265. AdminHelpPage.showHelpPage(activeChar, "spawns.htm");
  266. }
  267. }
  268. else if (command.startsWith("admin_list_spawns") || command.startsWith("admin_list_positions"))
  269. {
  270. int npcId = 0;
  271. int teleportIndex = -1;
  272. try
  273. { // admin_list_spawns x[xxxx] x[xx]
  274. String[] params = command.split(" ");
  275. Pattern pattern = Pattern.compile("[0-9]*");
  276. Matcher regexp = pattern.matcher(params[1]);
  277. if (regexp.matches())
  278. npcId = Integer.parseInt(params[1]);
  279. else
  280. {
  281. params[1] = params[1].replace('_', ' ');
  282. npcId = NpcTable.getInstance().getTemplateByName(params[1]).npcId;
  283. }
  284. if (params.length > 2)
  285. teleportIndex = Integer.parseInt(params[2]);
  286. }
  287. catch (Exception e)
  288. {
  289. activeChar.sendMessage("Command format is //list_spawns <npcId|npc_name> [tele_index]");
  290. }
  291. if(command.startsWith("admin_list_positions"))
  292. SpawnTable.getInstance().findNPCInstances(activeChar, npcId, teleportIndex, true);
  293. else
  294. SpawnTable.getInstance().findNPCInstances(activeChar, npcId, teleportIndex, false);
  295. }
  296. return true;
  297. }
  298. public String[] getAdminCommandList()
  299. {
  300. return ADMIN_COMMANDS;
  301. }
  302. private void printSpawn(L2Npc target, int type)
  303. {
  304. int i = target.getNpcId();
  305. int x = target.getSpawn().getLocx();
  306. int y = target.getSpawn().getLocy();
  307. int z = target.getSpawn().getLocz();
  308. int h = target.getSpawn().getHeading();
  309. switch(type)
  310. {
  311. default:
  312. case 0:
  313. _log.info("('',1,"+i+","+x+","+y+","+z+",0,0,"+h+",60,0,0),");
  314. break;
  315. case 1:
  316. _log.info("<spawn npcId=\""+i+"\" x=\""+x+"\" y=\""+y+"\" z=\""+z+"\" heading=\""+h+"\" respawn=\"0\" />");
  317. break;
  318. case 2:
  319. _log.info("{ "+i+", "+x+", "+y+", "+z+", "+h+" },");
  320. break;
  321. }
  322. }
  323. private void spawnMonster(L2PcInstance activeChar, String monsterId, int respawnTime, int mobCount, boolean permanent)
  324. {
  325. L2Object target = activeChar.getTarget();
  326. if (target == null)
  327. target = activeChar;
  328. L2NpcTemplate template1;
  329. if (monsterId.matches("[0-9]*"))
  330. {
  331. //First parameter was an ID number
  332. int monsterTemplate = Integer.parseInt(monsterId);
  333. template1 = NpcTable.getInstance().getTemplate(monsterTemplate);
  334. }
  335. else
  336. {
  337. //First parameter wasn't just numbers so go by name not ID
  338. monsterId = monsterId.replace('_', ' ');
  339. template1 = NpcTable.getInstance().getTemplateByName(monsterId);
  340. }
  341. try
  342. {
  343. L2Spawn spawn = new L2Spawn(template1);
  344. if (Config.SAVE_GMSPAWN_ON_CUSTOM)
  345. spawn.setCustom(true);
  346. spawn.setLocx(target.getX());
  347. spawn.setLocy(target.getY());
  348. spawn.setLocz(target.getZ());
  349. spawn.setAmount(mobCount);
  350. spawn.setHeading(activeChar.getHeading());
  351. spawn.setRespawnDelay(respawnTime);
  352. if (activeChar.getInstanceId() > 0)
  353. {
  354. spawn.setInstanceId(activeChar.getInstanceId());
  355. permanent = false;
  356. }
  357. else
  358. spawn.setInstanceId(0);
  359. // TODO add checks for GrandBossSpawnManager
  360. if (RaidBossSpawnManager.getInstance().isDefined(spawn.getNpcid()))
  361. activeChar.sendMessage("You cannot spawn another instance of " + template1.name + ".");
  362. else
  363. {
  364. if (RaidBossSpawnManager.getInstance().getValidTemplate(spawn.getNpcid()) != null)
  365. {
  366. spawn.setRespawnMinDelay(43200);
  367. spawn.setRespawnMaxDelay(129600);
  368. RaidBossSpawnManager.getInstance().addNewSpawn(spawn, 0, template1.baseHpMax, template1.baseMpMax, permanent);
  369. }
  370. else
  371. {
  372. SpawnTable.getInstance().addNewSpawn(spawn, permanent);
  373. spawn.init();
  374. }
  375. if (!permanent)
  376. spawn.stopRespawn();
  377. activeChar.sendMessage("Created " + template1.name + " on " + target.getObjectId());
  378. }
  379. }
  380. catch (Exception e)
  381. {
  382. activeChar.sendPacket(SystemMessage.getSystemMessage(SystemMessageId.TARGET_CANT_FOUND));
  383. }
  384. }
  385. private void showMonsters(L2PcInstance activeChar, int level, int from)
  386. {
  387. L2NpcTemplate[] mobs = NpcTable.getInstance().getAllMonstersOfLevel(level);
  388. final StringBuilder tb = StringUtil.startAppend(500 + mobs.length * 80,
  389. "<html><title>Spawn Monster:</title><body><p> Level : ",
  390. Integer.toString(level),
  391. "<br>Total Npc's : ",
  392. Integer.toString(mobs.length),
  393. "<br>");
  394. // Loop
  395. int i = from;
  396. for (int j = 0; i < mobs.length && j < 50; i++, j++)
  397. StringUtil.append(tb, "<a action=\"bypass -h admin_spawn_monster ", Integer.toString(mobs[i].npcId), "\">", mobs[i].name, "</a><br1>");
  398. if (i == mobs.length)
  399. tb.append("<br><center><button value=\"Back\" action=\"bypass -h admin_show_spawns\" width=40 height=15 back=\"L2UI_ct1.button_df\" fore=\"L2UI_ct1.button_df\"></center></body></html>");
  400. else
  401. StringUtil.append(tb, "<br><center><button value=\"Next\" action=\"bypass -h admin_spawn_index ", Integer.toString(level), " ", Integer.toString(i), "\" width=40 height=15 back=\"L2UI_ct1.button_df\" fore=\"L2UI_ct1.button_df\"><button value=\"Back\" action=\"bypass -h admin_show_spawns\" width=40 height=15 back=\"L2UI_ct1.button_df\" fore=\"L2UI_ct1.button_df\"></center></body></html>");
  402. activeChar.sendPacket(new NpcHtmlMessage(5, tb.toString()));
  403. }
  404. private void showNpcs(L2PcInstance activeChar, String starting, int from)
  405. {
  406. L2NpcTemplate[] mobs = NpcTable.getInstance().getAllNpcStartingWith(starting);
  407. final StringBuilder tb = StringUtil.startAppend(500 + mobs.length * 80,
  408. "<html><title>Spawn Monster:</title><body><p> There are ",
  409. Integer.toString(mobs.length),
  410. " Npcs whose name starts with ",
  411. starting,
  412. ":<br>");
  413. // Loop
  414. int i = from;
  415. for (int j = 0; i < mobs.length && j < 50; i++, j++)
  416. StringUtil.append(tb, "<a action=\"bypass -h admin_spawn_monster ", Integer.toString(mobs[i].npcId), "\">", mobs[i].name, "</a><br1>");
  417. if (i == mobs.length)
  418. tb.append("<br><center><button value=\"Back\" action=\"bypass -h admin_show_npcs\" width=40 height=15 back=\"L2UI_ct1.button_df\" fore=\"L2UI_ct1.button_df\"></center></body></html>");
  419. else
  420. StringUtil.append(tb, "<br><center><button value=\"Next\" action=\"bypass -h admin_npc_index ", starting, " ", Integer.toString(i), "\" width=40 height=15 back=\"L2UI_ct1.button_df\" fore=\"L2UI_ct1.button_df\"><button value=\"Back\" action=\"bypass -h admin_show_npcs\" width=40 height=15 back=\"L2UI_ct1.button_df\" fore=\"L2UI_ct1.button_df\"></center></body></html>");
  421. activeChar.sendPacket(new NpcHtmlMessage(5, tb.toString()));
  422. }
  423. }