RainbowSpringsChateau.java 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797
  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 conquerablehalls.RainbowSpringsChateau;
  16. import gnu.trove.map.hash.TIntLongHashMap;
  17. import java.sql.Connection;
  18. import java.sql.PreparedStatement;
  19. import java.sql.ResultSet;
  20. import java.util.ArrayList;
  21. import java.util.Calendar;
  22. import java.util.Date;
  23. import java.util.HashMap;
  24. import java.util.List;
  25. import java.util.Map;
  26. import java.util.concurrent.ScheduledFuture;
  27. import java.util.logging.Logger;
  28. import com.l2jserver.L2DatabaseFactory;
  29. import com.l2jserver.gameserver.Announcements;
  30. import com.l2jserver.gameserver.ThreadPoolManager;
  31. import com.l2jserver.gameserver.datatables.ClanTable;
  32. import com.l2jserver.gameserver.datatables.NpcTable;
  33. import com.l2jserver.gameserver.datatables.SkillTable;
  34. import com.l2jserver.gameserver.datatables.SpawnTable;
  35. import com.l2jserver.gameserver.instancemanager.CHSiegeManager;
  36. import com.l2jserver.gameserver.instancemanager.MapRegionManager.TeleportWhereType;
  37. import com.l2jserver.gameserver.instancemanager.ZoneManager;
  38. import com.l2jserver.gameserver.model.L2Clan;
  39. import com.l2jserver.gameserver.model.L2Object;
  40. import com.l2jserver.gameserver.model.L2Skill;
  41. import com.l2jserver.gameserver.model.L2Spawn;
  42. import com.l2jserver.gameserver.model.actor.L2Character;
  43. import com.l2jserver.gameserver.model.actor.L2Npc;
  44. import com.l2jserver.gameserver.model.actor.instance.L2PcInstance;
  45. import com.l2jserver.gameserver.model.entity.clanhall.SiegableHall;
  46. import com.l2jserver.gameserver.model.entity.clanhall.SiegeStatus;
  47. import com.l2jserver.gameserver.model.item.L2Item;
  48. import com.l2jserver.gameserver.model.item.instance.L2ItemInstance;
  49. import com.l2jserver.gameserver.model.quest.Quest;
  50. import com.l2jserver.gameserver.model.quest.QuestState;
  51. import com.l2jserver.gameserver.model.quest.State;
  52. import com.l2jserver.gameserver.network.clientpackets.Say2;
  53. import com.l2jserver.gameserver.network.serverpackets.NpcHtmlMessage;
  54. import com.l2jserver.gameserver.network.serverpackets.NpcSay;
  55. import com.l2jserver.gameserver.util.L2TIntObjectHashMap;
  56. import com.l2jserver.util.Rnd;
  57. /**
  58. * @author BiggBoss
  59. * Rainbow Springs Chateau clan hall siege script
  60. */
  61. public class RainbowSpringsChateau extends Quest
  62. {
  63. private static final Logger _log = Logger.getLogger(RainbowSpringsChateau.class.getName());
  64. private static class SetFinalAttackers implements Runnable
  65. {
  66. @Override
  67. public void run()
  68. {
  69. if(_rainbow == null)
  70. _rainbow = CHSiegeManager.getInstance().getSiegableHall(RAINBOW_SPRINGS);
  71. int spotLeft = 4;
  72. if(_rainbow.getOwnerId() > 0)
  73. {
  74. L2Clan owner = ClanTable.getInstance().getClan(_rainbow.getOwnerId());
  75. if(owner != null)
  76. {
  77. _rainbow.free();
  78. owner.setHasHideout(0);
  79. _acceptedClans.add(owner);
  80. --spotLeft;
  81. }
  82. for(int i = 0; i < spotLeft; i++)
  83. {
  84. long counter = 0;
  85. L2Clan clan = null;
  86. for(int clanId : _warDecreesCount.keys())
  87. {
  88. L2Clan actingClan = ClanTable.getInstance().getClan(clanId);
  89. if(actingClan == null || actingClan.getDissolvingExpiryTime() > 0)
  90. {
  91. _warDecreesCount.remove(clanId);
  92. continue;
  93. }
  94. final long count = _warDecreesCount.get(clanId);
  95. if(count > counter)
  96. { counter = count;
  97. clan = actingClan;
  98. }
  99. }
  100. if(_acceptedClans.size() < 4)
  101. {
  102. _acceptedClans.add(clan);
  103. L2PcInstance leader = clan.getLeader().getPlayerInstance();
  104. if(leader != null)
  105. leader.sendMessage("Your clan has been accepted to join the RainBow Srpings Chateau siege!");
  106. }
  107. }
  108. if(_acceptedClans.size() >= 2)
  109. {
  110. _nextSiege = ThreadPoolManager.getInstance().scheduleGeneral(new SiegeStart(), 3600000);
  111. _rainbow.updateSiegeStatus(SiegeStatus.WAITING_BATTLE);
  112. }
  113. else
  114. Announcements.getInstance().announceToAll("Rainbow Springs Chateau siege aborted due lack of population");
  115. }
  116. }
  117. }
  118. private static class SiegeStart implements Runnable
  119. {
  120. @Override
  121. public void run()
  122. {
  123. if(_rainbow == null)
  124. _rainbow = CHSiegeManager.getInstance().getSiegableHall(RAINBOW_SPRINGS);
  125. //XXX _rainbow.siegeStarts();
  126. spawnGourds();
  127. _siegeEnd = ThreadPoolManager.getInstance().scheduleGeneral(new SiegeEnd(null), _rainbow.getSiegeLenght() - 120000);
  128. }
  129. }
  130. private static class SiegeEnd implements Runnable
  131. {
  132. private L2Clan _winner;
  133. private SiegeEnd(L2Clan winner)
  134. {
  135. _winner = winner;
  136. }
  137. @Override
  138. public void run()
  139. {
  140. if(_rainbow == null)
  141. _rainbow = CHSiegeManager.getInstance().getSiegableHall(RAINBOW_SPRINGS);
  142. unSpawnGourds();
  143. if(_winner != null)
  144. _rainbow.setOwner(_winner);
  145. //XXX _rainbow.siegeEnds();
  146. ThreadPoolManager.getInstance().scheduleGeneral(new SetFinalAttackers(), _rainbow.getNextSiegeTime());
  147. setRegistrationEndString(_rainbow.getNextSiegeTime() + System.currentTimeMillis() - 3600000);
  148. // Teleport out of the arenas is made 2 mins after game ends
  149. ThreadPoolManager.getInstance().scheduleGeneral(new TeleportBack(), 120000);
  150. }
  151. }
  152. private static class TeleportBack implements Runnable
  153. {
  154. @Override
  155. public void run()
  156. {
  157. for(int arenaId : ARENA_ZONES)
  158. {
  159. final L2TIntObjectHashMap<L2Character> chars = ZoneManager.getInstance().getZoneById(arenaId).getCharactersInside();
  160. for(L2Character chr : chars.valueCollection())
  161. chr.teleToLocation(TeleportWhereType.Town);
  162. }
  163. }
  164. }
  165. private static final String qn = "RainbowSpringsChateau";
  166. private static final int RAINBOW_SPRINGS = 62;
  167. private static final int WAR_DECREES = 8034;
  168. private static final int RAINBOW_NECTAR= 8030;
  169. private static final int RAINBOW_MWATER = 8031;
  170. private static final int RAINBOW_WATER = 8032;
  171. private static final int RAINBOW_SULFUR = 8033;
  172. private static final int MESSENGER = 35604;
  173. private static final int CARETAKER = 35603;
  174. private static final int CHEST = 35593;
  175. private static final int[] GOURDS = { 35588, 35589, 35590, 35591 };
  176. private static L2Spawn[] _gourds = new L2Spawn[4];
  177. private static final int[] YETIS = { 35596, 35597, 35598, 35599 };
  178. private static final int[][] ARENAS =
  179. {
  180. { 151562, -127080, -2214 }, // Arena 1
  181. { 153141, -125335, -2214 }, // Arena 2
  182. { 153892, -127530, -2214 }, // Arena 3
  183. { 155657, -125752, -2214 }, // Arena 4
  184. };
  185. private static final int[] ARENA_ZONES = { 112081, 112082, 112083, 112084 };
  186. private static final String[] _textPassages =
  187. {
  188. "Text Passage 1",
  189. "Passage Text 2",
  190. "Im getting out of ideas",
  191. "But i can write few more",
  192. "Are five sentences",
  193. "enough for this f*** siege?",
  194. "i think ill add few more",
  195. "like this one",
  196. "Please, if you know the true passages",
  197. "Contact me at L2JForum =)"
  198. };
  199. private static final L2Skill[] DEBUFFS =
  200. {
  201. SkillTable.getInstance().getInfo(0, 1)
  202. };
  203. private static TIntLongHashMap _warDecreesCount = new TIntLongHashMap();
  204. private static List<L2Clan> _acceptedClans = new ArrayList<L2Clan>(4);
  205. private static Map<String, ArrayList<L2Clan>> _usedTextPassages = new HashMap<String, ArrayList<L2Clan>>();
  206. private static Map<L2Clan, Integer> _pendingItemToGet = new HashMap<L2Clan, Integer>();
  207. private static SiegableHall _rainbow;
  208. private static ScheduledFuture<?> _nextSiege, _siegeEnd;
  209. private static String _registrationEnds;
  210. /**
  211. * @param questId
  212. * @param name
  213. * @param descr
  214. */
  215. public RainbowSpringsChateau(int questId, String name, String descr)
  216. {
  217. super(questId, name, descr);
  218. addFirstTalkId(MESSENGER);
  219. addTalkId(MESSENGER);
  220. addFirstTalkId(CARETAKER);
  221. addTalkId(CARETAKER);
  222. for(int npc : YETIS)
  223. {
  224. addFirstTalkId(npc);
  225. addTalkId(npc);
  226. }
  227. loadAttackers();
  228. _rainbow = CHSiegeManager.getInstance().getSiegableHall(RAINBOW_SPRINGS);
  229. if(_rainbow != null)
  230. {
  231. long delay = _rainbow.getNextSiegeTime();
  232. if(delay > -1)
  233. {
  234. setRegistrationEndString(delay - 3600000);
  235. _nextSiege = ThreadPoolManager.getInstance().scheduleGeneral(new SetFinalAttackers(), delay);
  236. }
  237. else
  238. _log.warning("CHSiegeManager: No Date setted for RainBow Springs Chateau Clan hall siege!. SIEGE CANCELED!");
  239. }
  240. }
  241. @Override
  242. public String onFirstTalk(L2Npc npc, L2PcInstance player)
  243. {
  244. if(player.getQuestState(qn) == null)
  245. {
  246. QuestState state = newQuestState(player);
  247. state.setState(State.STARTED);
  248. }
  249. int npcId = npc.getNpcId();
  250. String html = "";
  251. if(npcId == MESSENGER)
  252. {
  253. sendMessengerMain(player);
  254. }
  255. else if(npcId == CARETAKER)
  256. {
  257. html = "caretaker_main.htm";
  258. }
  259. else if(_rainbow.isInSiege())
  260. {
  261. if(!player.isClanLeader())
  262. html = "no_clan_leader.htm";
  263. else
  264. {
  265. L2Clan clan = player.getClan();
  266. if(clan != null && _acceptedClans.contains(clan))
  267. {
  268. int index = _acceptedClans.indexOf(clan);
  269. if(npcId == YETIS[index])
  270. html = "yeti_main.htm";
  271. }
  272. }
  273. }
  274. player.setLastQuestNpcObject(npc.getObjectId());
  275. return html;
  276. }
  277. @Override
  278. public String onAdvEvent(String event, L2Npc npc, L2PcInstance player)
  279. {
  280. if(!player.isClanLeader())
  281. return "no_clan_leader.htm";
  282. String html = event;
  283. final L2Clan clan = player.getClan();
  284. final int clanId = clan.getClanId();
  285. if(event.equals("register"))
  286. {
  287. if(!_rainbow.isRegistering())
  288. html = "messenger_not_registering.htm";
  289. else if(_warDecreesCount.containsKey(clanId))
  290. html = "messenger_alredy_registered.htm";
  291. else if(clan.getLevel() < 3 || clan.getMembersCount() < 5)
  292. html = "messenger_no_level.htm";
  293. else
  294. {
  295. L2ItemInstance warDecrees = player.getInventory().getItemByItemId(WAR_DECREES);
  296. if(warDecrees == null)
  297. html = "messenger_nowardecrees.htm";
  298. else
  299. {
  300. long count = warDecrees.getCount();
  301. _warDecreesCount.put(clanId, count);
  302. player.destroyItem("Rainbow Springs Registration", warDecrees, npc, true);
  303. updateAttacker(clanId, count, false);
  304. html = "messenger_registered.htm";
  305. }
  306. }
  307. }
  308. else if(event.equals("unregister"))
  309. {
  310. if(!_warDecreesCount.containsKey(clanId))
  311. html = "messenger_notinlist.htm";
  312. else if(_rainbow.isRegistering())
  313. {
  314. String[] split = event.split("_");
  315. int step = Integer.parseInt(split[1]);
  316. switch(step)
  317. {
  318. case 0:
  319. html = "messenger_unregister_confirmation.htm";
  320. break;
  321. case 1:
  322. html = "messenger_retrive_wardecrees.htm";
  323. updateAttacker(clanId, 0, true);
  324. break;
  325. case 2:
  326. html = "messenger_unregistered.htm";
  327. long toRetrive = _warDecreesCount.get(clanId) / 2;
  328. player.addItem("Rainbow Spring unregister", WAR_DECREES, toRetrive, npc, true);
  329. _warDecreesCount.remove(clanId);
  330. break;
  331. default:
  332. html = "messenger_main.htm";
  333. }
  334. }
  335. else if(_rainbow.isWaitingBattle())
  336. {
  337. if(!_acceptedClans.contains(clan))
  338. return "messenger_notinlist.htm";
  339. String[] split = event.split("_");
  340. int step = Integer.parseInt(split[1]);
  341. switch(step)
  342. {
  343. case 0:
  344. html = "messenger_unregister_confirmation_no_retrive.htm";
  345. break;
  346. case 1:
  347. html = "messenger_unregistered.htm";
  348. _acceptedClans.remove(clan);
  349. break;
  350. default:
  351. html = "messenger_main.htm";
  352. }
  353. }
  354. }
  355. else if(event.equals("portToArena"))
  356. {
  357. if(!_acceptedClans.contains(clan))
  358. html = "caretaker_not_allowed.htm";
  359. else if(player.getParty() == null)
  360. html = "caretaker_no_party.htm";
  361. else
  362. {
  363. int index = _acceptedClans.indexOf(clan);
  364. portToArena(player, index);
  365. }
  366. }
  367. else if(event.startsWith("enterText"))
  368. {
  369. // Shouldnt happen
  370. if(!_acceptedClans.contains(clan))
  371. return null;
  372. String[] split = event.split("_");
  373. if(split.length < 2)
  374. return null;
  375. final String passage = split[1];
  376. if(!isValidPassage(passage))
  377. return null;
  378. if(_usedTextPassages.containsKey(passage))
  379. {
  380. ArrayList<L2Clan> list = _usedTextPassages.get(passage);
  381. if(list.contains(clan))
  382. html = "yeti_passage_used.htm";
  383. else
  384. {
  385. list.add(clan);
  386. synchronized(_pendingItemToGet)
  387. {
  388. if(_pendingItemToGet.containsKey(clan))
  389. {
  390. int left = _pendingItemToGet.get(clan);
  391. ++left;
  392. _pendingItemToGet.put(clan, left);
  393. }
  394. else
  395. _pendingItemToGet.put(clan, 1);
  396. }
  397. html = "yeti_item_exchange.htm";
  398. }
  399. }
  400. }
  401. else if(event.startsWith("getItem"))
  402. {
  403. if(!_pendingItemToGet.containsKey(clanId))
  404. html = "yeti_cannot_exchange.htm";
  405. int left = _pendingItemToGet.get(clan);
  406. if(left > 0)
  407. {
  408. int itemId = Integer.parseInt(event.split("_")[1]);
  409. player.addItem("Rainbow Spring Chateau Siege", itemId, 1, npc, true);
  410. --left;
  411. _pendingItemToGet.put(clan, left);
  412. html = "yeti_main.htm";
  413. }
  414. else
  415. html = "yeti_cannot_exchange.htm";
  416. }
  417. return html;
  418. }
  419. @Override
  420. public String onKill(L2Npc npc, L2PcInstance killer, boolean isPet)
  421. {
  422. if(!_rainbow.isInSiege())
  423. return null;
  424. final L2Clan clan = killer.getClan();
  425. if(clan == null || !_acceptedClans.contains(clan))
  426. return null;
  427. final int npcId = npc.getNpcId();
  428. final int index = _acceptedClans.indexOf(clan);
  429. if(npcId == CHEST)
  430. {
  431. shoutRandomText(npc);
  432. }
  433. else if(npcId == GOURDS[index])
  434. {
  435. synchronized(this)
  436. {
  437. if(_siegeEnd != null)
  438. _siegeEnd.cancel(false);
  439. ThreadPoolManager.getInstance().executeTask(new SiegeEnd(clan));
  440. }
  441. }
  442. return null;
  443. }
  444. @Override
  445. public String onItemUse(L2Item item, L2PcInstance player)
  446. {
  447. if(!_rainbow.isInSiege())
  448. return null;
  449. L2Object target = player.getTarget();
  450. if(target == null || !(target instanceof L2Npc))
  451. return null;
  452. int yeti = ((L2Npc)target).getNpcId();
  453. if(!isYetiTarget(yeti))
  454. return null;
  455. final L2Clan clan = player.getClan();
  456. if(clan == null || !_acceptedClans.contains(clan))
  457. return null;
  458. final int itemId = item.getItemId();
  459. // Nectar must spawn the enraged yeti. Dunno if it makes any other thing
  460. // Also, the items must execute:
  461. // - Reduce gourd hpb ( reduceGourdHp(int, L2PcInstance) )
  462. // - Cast debuffs on enemy clans ( castDebuffsOnEnemies(int) )
  463. // - Change arena gourds ( moveGourds() )
  464. // - Increase gourd hp ( increaseGourdHp(int) )
  465. if(itemId == RAINBOW_NECTAR)
  466. {
  467. // Spawn enraged (where?)
  468. reduceGourdHp(_acceptedClans.indexOf(clan), player);
  469. }
  470. else if(itemId == RAINBOW_MWATER)
  471. {
  472. increaseGourdHp(_acceptedClans.indexOf(clan));
  473. }
  474. else if(itemId == RAINBOW_WATER)
  475. {
  476. moveGourds();
  477. }
  478. else if(itemId == RAINBOW_SULFUR)
  479. {
  480. castDebuffsOnEnemies(_acceptedClans.indexOf(clan));
  481. }
  482. return null;
  483. }
  484. private static void portToArena(L2PcInstance leader, int arena)
  485. {
  486. if(arena < 0 || arena > 3)
  487. {
  488. _log.warning("RainbowSptringChateau siege: Wrong arena id passed: "+arena);
  489. return;
  490. }
  491. for(L2PcInstance pc : leader.getParty().getPartyMembers())
  492. if(pc != null)
  493. {
  494. pc.stopAllEffects();
  495. if(pc.getPet() != null)
  496. pc.getPet().unSummon(pc);
  497. pc.teleToLocation(ARENAS[arena][0], ARENAS[arena][1], ARENAS[arena][2]);
  498. }
  499. }
  500. private static void spawnGourds()
  501. {
  502. for(int i = 0; i < _acceptedClans.size(); i++)
  503. {
  504. if(_gourds[i] == null)
  505. {
  506. try
  507. {
  508. _gourds[i] = new L2Spawn(NpcTable.getInstance().getTemplate(GOURDS[i]));
  509. _gourds[i].setLocx(ARENAS[i][0] + 150);
  510. _gourds[i].setLocy(ARENAS[i][1] + 150);
  511. _gourds[i].setLocz(ARENAS[i][2]);
  512. _gourds[i].setHeading(1);
  513. _gourds[i].setAmount(1);
  514. }
  515. catch(Exception e)
  516. {
  517. e.printStackTrace();
  518. }
  519. }
  520. SpawnTable.getInstance().addNewSpawn(_gourds[i], false);
  521. _gourds[i].init();
  522. }
  523. }
  524. private static void unSpawnGourds()
  525. {
  526. for(int i = 0; i < _acceptedClans.size(); i++)
  527. {
  528. _gourds[i].getLastSpawn().deleteMe();
  529. SpawnTable.getInstance().deleteSpawn(_gourds[i], false);
  530. }
  531. }
  532. private static void moveGourds()
  533. {
  534. L2Spawn[] tempArray = _gourds;
  535. int iterator = _acceptedClans.size();
  536. for(int i = 0; i < iterator; i++)
  537. {
  538. L2Spawn oldSpawn = _gourds[(iterator-1)-i];
  539. L2Spawn curSpawn = tempArray[i];
  540. _gourds[(iterator -1) - i] = curSpawn;
  541. int newX = oldSpawn.getLocx();
  542. int newY = oldSpawn.getLocy();
  543. int newZ = oldSpawn.getLocz();
  544. curSpawn.getLastSpawn().teleToLocation(newX, newY, newZ);
  545. }
  546. }
  547. private static void reduceGourdHp(int index, L2PcInstance player)
  548. {
  549. L2Spawn gourd = _gourds[index];
  550. gourd.getLastSpawn().reduceCurrentHp(1000, player, null);
  551. }
  552. private static void increaseGourdHp(int index)
  553. {
  554. L2Spawn gourd = _gourds[index];
  555. L2Npc gourdNpc = gourd.getLastSpawn();
  556. gourdNpc.setCurrentHp(gourdNpc.getCurrentHp() + 1000);
  557. }
  558. private static void castDebuffsOnEnemies(int myArena)
  559. {
  560. for(int id : ARENA_ZONES)
  561. {
  562. if(id == myArena)
  563. continue;
  564. final L2TIntObjectHashMap<L2Character> chars = ZoneManager.getInstance().getZoneById(id).getCharactersInside();
  565. for(L2Character chr : chars.valueCollection())
  566. {
  567. for(L2Skill sk : DEBUFFS)
  568. sk.getEffects(chr, chr);
  569. }
  570. }
  571. }
  572. private static void shoutRandomText(L2Npc npc)
  573. {
  574. int length = _textPassages.length;
  575. if(_usedTextPassages.size() >= length)
  576. return;
  577. int randomPos = Rnd.get(length);
  578. String message = _textPassages[randomPos];
  579. if(_usedTextPassages.containsKey(message))
  580. shoutRandomText(npc);
  581. else
  582. {
  583. _usedTextPassages.put(message, new ArrayList<L2Clan>());
  584. int shout = Say2.SHOUT;
  585. int objId = npc.getObjectId();
  586. NpcSay say = new NpcSay(objId, shout, npc.getNpcId(), message);
  587. npc.broadcastPacket(say);
  588. }
  589. }
  590. private static boolean isValidPassage(String text)
  591. {
  592. for(String st : _textPassages)
  593. if(st.equalsIgnoreCase(text))
  594. return true;
  595. return false;
  596. }
  597. private static boolean isYetiTarget(int npcId)
  598. {
  599. for(int yeti : YETIS)
  600. if(yeti == npcId)
  601. return true;
  602. return false;
  603. }
  604. private static void updateAttacker(int clanId, long count, boolean remove)
  605. {
  606. Connection con = null;
  607. try
  608. {
  609. con = L2DatabaseFactory.getInstance().getConnection();
  610. PreparedStatement statement;
  611. if(remove)
  612. {
  613. statement = con.prepareStatement("DELETE FROM rainbowsprings_attacker_list WHERE clanId = ?");
  614. statement.setInt(1, clanId);
  615. }
  616. else
  617. {
  618. statement = con.prepareStatement("INSERT INTO rainbowsprings_attacker_list VALUES (?,?)");
  619. statement.setInt(1, clanId);
  620. statement.setLong(2, count);
  621. }
  622. statement.execute();
  623. statement.close();
  624. }
  625. catch(Exception e)
  626. {
  627. e.printStackTrace();
  628. }
  629. finally
  630. {
  631. L2DatabaseFactory.close(con);
  632. }
  633. }
  634. private static void loadAttackers()
  635. {
  636. Connection con = null;
  637. try
  638. {
  639. con = L2DatabaseFactory.getInstance().getConnection();
  640. PreparedStatement statement = con.prepareStatement("SELECT * FROM rainbowsprings_attacker_list");
  641. ResultSet rset = statement.executeQuery();
  642. while(rset.next())
  643. {
  644. int clanId = rset.getInt("clan_id");
  645. long count = rset.getLong("decrees_count");
  646. _warDecreesCount.put(clanId, count);
  647. }
  648. rset.close();
  649. statement.close();
  650. }
  651. catch(Exception e)
  652. {
  653. e.printStackTrace();
  654. }
  655. finally
  656. {
  657. L2DatabaseFactory.close(con);
  658. }
  659. }
  660. private static void setRegistrationEndString(long time)
  661. {
  662. Calendar c = Calendar.getInstance();
  663. c.setTime(new Date(time));
  664. int year = c.get(Calendar.YEAR);
  665. int month = c.get(Calendar.MONTH) + 1;
  666. int day = c.get(Calendar.DAY_OF_MONTH);
  667. int hour = c.get(Calendar.HOUR);
  668. int mins = c.get(Calendar.MINUTE);
  669. _registrationEnds = year+"-"+month+"-"+day+" "+hour+":"+mins;
  670. }
  671. private static void sendMessengerMain(L2PcInstance player)
  672. {
  673. NpcHtmlMessage message = new NpcHtmlMessage(5);
  674. message.setFile(null, "data/scripts/conquerablehalls/RainbowSpringsChateau/messenger_main.htm");
  675. message.replace("%time%", _registrationEnds);
  676. player.sendPacket(message);
  677. }
  678. public static void launchSiege()
  679. {
  680. _nextSiege.cancel(false);
  681. ThreadPoolManager.getInstance().executeTask(new SiegeStart());
  682. }
  683. public static void endSiege()
  684. {
  685. if(_siegeEnd != null)
  686. _siegeEnd.cancel(false);
  687. ThreadPoolManager.getInstance().executeTask(new SiegeEnd(null));
  688. }
  689. public static void updateAdminDate(long date)
  690. {
  691. if(_rainbow == null)
  692. _rainbow = CHSiegeManager.getInstance().getSiegableHall(RAINBOW_SPRINGS);
  693. _rainbow.setNextSiegeDate(date);
  694. if(_nextSiege != null)
  695. _nextSiege.cancel(true);
  696. date -= 3600000;
  697. setRegistrationEndString(date);
  698. _nextSiege = ThreadPoolManager.getInstance().scheduleGeneral(new SetFinalAttackers(), _rainbow.getNextSiegeTime());
  699. }
  700. public static void main(String[] args)
  701. {
  702. new RainbowSpringsChateau(-1, qn, "conquerablehalls");
  703. }
  704. }