ClanWarsList.java 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. /*
  2. * Copyright (C) 2004-2015 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.usercommandhandlers;
  20. import java.sql.Connection;
  21. import java.sql.PreparedStatement;
  22. import java.sql.ResultSet;
  23. import java.util.logging.Level;
  24. import java.util.logging.Logger;
  25. import com.l2jserver.commons.database.pool.impl.ConnectionFactory;
  26. import com.l2jserver.gameserver.handler.IUserCommandHandler;
  27. import com.l2jserver.gameserver.model.L2Clan;
  28. import com.l2jserver.gameserver.model.actor.instance.L2PcInstance;
  29. import com.l2jserver.gameserver.network.SystemMessageId;
  30. import com.l2jserver.gameserver.network.serverpackets.SystemMessage;
  31. /**
  32. * Clan War Start, Under Attack List, War List user commands.
  33. * @author Tempy
  34. */
  35. public class ClanWarsList implements IUserCommandHandler
  36. {
  37. private static final Logger _log = Logger.getLogger(ClanWarsList.class.getName());
  38. private static final int[] COMMAND_IDS =
  39. {
  40. 88,
  41. 89,
  42. 90
  43. };
  44. // SQL queries
  45. private static final String ATTACK_LIST = "SELECT clan_name,clan_id,ally_id,ally_name FROM clan_data,clan_wars WHERE clan1=? AND clan_id=clan2 AND clan2 NOT IN (SELECT clan1 FROM clan_wars WHERE clan2=?)";
  46. private static final String UNDER_ATTACK_LIST = "SELECT clan_name,clan_id,ally_id,ally_name FROM clan_data,clan_wars WHERE clan2=? AND clan_id=clan1 AND clan1 NOT IN (SELECT clan2 FROM clan_wars WHERE clan1=?)";
  47. private static final String WAR_LIST = "SELECT clan_name,clan_id,ally_id,ally_name FROM clan_data,clan_wars WHERE clan1=? AND clan_id=clan2 AND clan2 IN (SELECT clan1 FROM clan_wars WHERE clan2=?)";
  48. @Override
  49. public boolean useUserCommand(int id, L2PcInstance activeChar)
  50. {
  51. if ((id != COMMAND_IDS[0]) && (id != COMMAND_IDS[1]) && (id != COMMAND_IDS[2]))
  52. {
  53. return false;
  54. }
  55. final L2Clan clan = activeChar.getClan();
  56. if (clan == null)
  57. {
  58. activeChar.sendPacket(SystemMessageId.NOT_JOINED_IN_ANY_CLAN);
  59. return false;
  60. }
  61. String query;
  62. // Attack List
  63. if (id == 88)
  64. {
  65. activeChar.sendPacket(SystemMessageId.CLANS_YOU_DECLARED_WAR_ON);
  66. query = ATTACK_LIST;
  67. }
  68. // Under Attack List
  69. else if (id == 89)
  70. {
  71. activeChar.sendPacket(SystemMessageId.CLANS_THAT_HAVE_DECLARED_WAR_ON_YOU);
  72. query = UNDER_ATTACK_LIST;
  73. }
  74. // War List
  75. else
  76. {
  77. activeChar.sendPacket(SystemMessageId.WAR_LIST);
  78. query = WAR_LIST;
  79. }
  80. try (Connection con = ConnectionFactory.getInstance().getConnection();
  81. PreparedStatement ps = con.prepareStatement(query))
  82. {
  83. ps.setInt(1, clan.getId());
  84. ps.setInt(2, clan.getId());
  85. SystemMessage sm;
  86. try (ResultSet rs = ps.executeQuery())
  87. {
  88. while (rs.next())
  89. {
  90. String clanName = rs.getString("clan_name");
  91. int allyId = rs.getInt("ally_id");
  92. if (allyId > 0)
  93. {
  94. // Target With Ally
  95. sm = SystemMessage.getSystemMessage(SystemMessageId.S1_S2_ALLIANCE);
  96. sm.addString(clanName);
  97. sm.addString(rs.getString("ally_name"));
  98. }
  99. else
  100. {
  101. // Target Without Ally
  102. sm = SystemMessage.getSystemMessage(SystemMessageId.S1_NO_ALLI_EXISTS);
  103. sm.addString(clanName);
  104. }
  105. activeChar.sendPacket(sm);
  106. }
  107. }
  108. activeChar.sendPacket(SystemMessageId.FRIEND_LIST_FOOTER);
  109. }
  110. catch (Exception e)
  111. {
  112. _log.log(Level.WARNING, "", e);
  113. }
  114. return true;
  115. }
  116. @Override
  117. public int[] getUserCommandList()
  118. {
  119. return COMMAND_IDS;
  120. }
  121. }