TradeDone.java 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  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 net.sf.l2j.gameserver.clientpackets;
  16. import java.util.logging.Logger;
  17. import net.sf.l2j.Config;
  18. import net.sf.l2j.gameserver.model.L2World;
  19. import net.sf.l2j.gameserver.model.TradeList;
  20. import net.sf.l2j.gameserver.model.actor.instance.L2PcInstance;
  21. import net.sf.l2j.gameserver.network.SystemMessageId;
  22. import net.sf.l2j.gameserver.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. L2PcInstance player = getClient().getActiveChar();
  42. if (player == null) return;
  43. TradeList trade = player.getActiveTradeList();
  44. if (trade == null)
  45. {
  46. if (Config.DEBUG)
  47. {
  48. _log.warning("player.getTradeList == null in "+getType()+" for player "+player.getName());
  49. }
  50. return;
  51. }
  52. if (trade.isLocked()) return;
  53. if (_response == 1)
  54. {
  55. if (trade.getPartner() == null || L2World.getInstance().findObject(trade.getPartner().getObjectId()) == null)
  56. {
  57. // Trade partner not found, cancel trade
  58. player.cancelActiveTrade();
  59. SystemMessage msg = new SystemMessage(SystemMessageId.TARGET_IS_NOT_FOUND_IN_THE_GAME);
  60. player.sendPacket(msg);
  61. msg = null;
  62. return;
  63. }
  64. if (trade.getOwner().getActiveEnchantItem() != null || trade.getPartner().getActiveEnchantItem() != null)
  65. return;
  66. if (!player.getAccessLevel().allowTransaction())
  67. {
  68. player.cancelActiveTrade();
  69. player.sendMessage("Transactions are disable for your Access Level");
  70. return;
  71. }
  72. trade.confirm();
  73. }
  74. else player.cancelActiveTrade();
  75. }
  76. /* (non-Javadoc)
  77. * @see net.sf.l2j.gameserver.clientpackets.ClientBasePacket#getType()
  78. */
  79. @Override
  80. public String getType()
  81. {
  82. return _C__17_TRADEDONE;
  83. }
  84. }