TradeDone.java 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  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 com.l2jserver.gameserver.network.clientpackets;
  16. import java.util.logging.Logger;
  17. import com.l2jserver.Config;
  18. import com.l2jserver.gameserver.model.L2World;
  19. import com.l2jserver.gameserver.model.TradeList;
  20. import com.l2jserver.gameserver.model.actor.instance.L2PcInstance;
  21. import com.l2jserver.gameserver.network.SystemMessageId;
  22. import com.l2jserver.gameserver.network.serverpackets.SystemMessage;
  23. /**
  24. * This class ...
  25. *
  26. * @version $Revision: 1.6.2.2.2.2 $ $Date: 2005/03/27 15:29:30 $
  27. */
  28. public final class TradeDone extends L2GameClientPacket
  29. {
  30. private static final String _C__17_TRADEDONE = "[C] 17 TradeDone";
  31. private static Logger _log = Logger.getLogger(TradeDone.class.getName());
  32. private int _response;
  33. @Override
  34. protected void readImpl()
  35. {
  36. _response = readD();
  37. }
  38. @Override
  39. protected void runImpl()
  40. {
  41. final L2PcInstance player = getClient().getActiveChar();
  42. if (player == null)
  43. return;
  44. if (!getClient().getFloodProtectors().getTransaction().tryPerformAction("trade"))
  45. {
  46. player.sendMessage("You trading too fast.");
  47. return;
  48. }
  49. final TradeList trade = player.getActiveTradeList();
  50. if (trade == null)
  51. {
  52. if (Config.DEBUG)
  53. _log.warning("player.getTradeList == null in " + getType() + " for player " + player.getName());
  54. return;
  55. }
  56. if (trade.isLocked())
  57. return;
  58. if (_response == 1)
  59. {
  60. if (trade.getPartner() == null || L2World.getInstance().getPlayer(trade.getPartner().getObjectId()) == null)
  61. {
  62. // Trade partner not found, cancel trade
  63. player.cancelActiveTrade();
  64. player.sendPacket(new SystemMessage(SystemMessageId.TARGET_IS_NOT_FOUND_IN_THE_GAME));
  65. return;
  66. }
  67. if (trade.getOwner().getActiveEnchantItem() != null || trade.getPartner().getActiveEnchantItem() != null)
  68. return;
  69. if (!player.getAccessLevel().allowTransaction())
  70. {
  71. player.cancelActiveTrade();
  72. player.sendPacket(new SystemMessage(SystemMessageId.YOU_ARE_NOT_AUTHORIZED_TO_DO_THAT));
  73. return;
  74. }
  75. if (player.getInstanceId() != trade.getPartner().getInstanceId() && player.getInstanceId() != -1)
  76. {
  77. player.cancelActiveTrade();
  78. return;
  79. }
  80. trade.confirm();
  81. }
  82. else
  83. player.cancelActiveTrade();
  84. }
  85. /* (non-Javadoc)
  86. * @see com.l2jserver.gameserver.clientpackets.ClientBasePacket#getType()
  87. */
  88. @Override
  89. public String getType()
  90. {
  91. return _C__17_TRADEDONE;
  92. }
  93. }