package org.l2jmobius.gameserver.network.clientpackets;
import org.l2jmobius.Config;
import org.l2jmobius.commons.network.ReadablePacket;
import org.l2jmobius.gameserver.model.PremiumItem;
import org.l2jmobius.gameserver.model.actor.Player;
import org.l2jmobius.gameserver.network.GameClient;
import org.l2jmobius.gameserver.network.SystemMessageId;
import org.l2jmobius.gameserver.network.serverpackets.ExGetPremiumItemList;
import org.l2jmobius.gameserver.util.Util;
/**
* @author Gnacik
*/
public class RequestWithDrawPremiumItem implements ClientPacket
{
private int _itemNum;
private int _charId;
private long _itemCount;
@Override
public void read(ReadablePacket packet)
{
_itemNum = packet.readInt();
_charId = packet.readInt();
_itemCount = packet.readLong();
}
@Override
public void run(GameClient client)
{
final Player player = client.getPlayer();
if (player == null)
{
return;
}
else if (_itemCount <= 0)
{
return;
}
else if (player.getObjectId() != _charId)
{
Util.handleIllegalPlayerAction(player, "[RequestWithDrawPremiumItem] Incorrect owner, Player: " + player.getName(), Config.DEFAULT_PUNISH);
return;
}
else if (player.getPremiumItemList().isEmpty())
{
Util.handleIllegalPlayerAction(player, "[RequestWithDrawPremiumItem] Player: " + player.getName() + " try to get item with empty list!", Config.DEFAULT_PUNISH);
return;
}
else if ((player.getWeightPenalty() >= 3) || !player.isInventoryUnder90(false))
{
player.sendPacket(SystemMessageId.YOU_CANNOT_RECEIVE_THE_DIMENSIONAL_ITEM_BECAUSE_YOU_HAVE_EXCEED_YOUR_INVENTORY_WEIGHT_QUANTITY_LIMIT);
return;
}
else if (player.isProcessingTransaction())
{
player.sendPacket(SystemMessageId.ITEMS_FROM_GAME_ASSISTANTS_CANNOT_BE_EXCHANGED);
return;
}
final PremiumItem item = player.getPremiumItemList().get(_itemNum);
if (item == null)
{
return;
}
else if (item.getCount() < _itemCount)
{
return;
}
final long itemsLeft = (item.getCount() - _itemCount);
player.addItem("PremiumItem", item.getItemId(), _itemCount, player.getTarget(), true);
if (itemsLeft > 0)
{
item.updateCount(itemsLeft);
player.updatePremiumItem(_itemNum, itemsLeft);
}
else
{
player.getPremiumItemList().remove(_itemNum);
player.deletePremiumItem(_itemNum);
}
if (player.getPremiumItemList().isEmpty())
{
player.sendPacket(SystemMessageId.THERE_ARE_NO_MORE_DIMENSIONAL_ITEMS_TO_BE_FOUND);
}
else
{
player.sendPacket(new ExGetPremiumItemList(player));
}
}
}
package l2p.gameserver.network.c2s;
import l2p.gameserver.config.OtherConfig;
import l2p.gameserver.holders.items.PremiumItem;
import l2p.gameserver.model.Player;
import l2p.gameserver.network.components.SystemMsg;
import l2p.gameserver.network.s2c.ActionFail;
import l2p.gameserver.network.s2c.ExGetPremiumItemList;
import l2p.gameserver.network.s2c.ExGoodsInventoryResult;
import l2p.gameserver.utils.ItemUtils;
public final class RequestWithdrawPremiumItem extends L2GameClientPacket
{
private int _uid;
private int _objectId;
private long _count;
@Override
protected void readImpl()
{
_uid = readD();
_objectId = readD();
_count = readQ();
}
@Override
protected void runImpl()
{
Player player = getClient().getActiveChar();
if (player == null)
return;
if (player.isActionsDisabled() || player.isInGoodsInventory())
{
player.sendPacket(ActionFail.STATIC);
return;
}
if (_count <= 0 || player.getObjectId() != _objectId || player.getPremiumItems().isEmpty())
{
player.sendPacket(ActionFail.STATIC);
return;
}
if (!ItemUtils.checkInventory(player, false))
{
player.sendPacket(SystemMsg.YOU_CANNOT_RECEIVE_THE_VITAMIN_ITEM_BECAUSE_YOU_HAVE_EXCEED_YOUR_INVENTORY_WEIGHT_OR_QUANTITY_LIMIT);
return;
}
if (player.isInTrade())
{
player.sendPacket(SystemMsg.YOU_CANNOT_RECEIVE_A_VITAMIN_ITEM_DURING_AN_EXCHANGE);
return;
}
if (player.isInPrivateStore())
{
player.sendPacket(SystemMsg.YOU_CANNOT_RECEIVE_BECAUSE_THE_PRIVATE_SHOP_OR_WORKSHOP_IS_IN_PROGRESS);
return;
}
PremiumItem item = player.getPremiumItems().getItem(_uid);
if (item == null || item.getCount() < _count)
{
player.sendPacket(ActionFail.STATIC);
return;
}
player.setInGoodsInventory(true);
try
{
ItemUtils.addItem(player, item.getItemId(), _count);
player.getPremiumItems().updateItem(_uid, item.getCount() - _count);
}
catch (Exception e)
{}
finally
{
player.setInGoodsInventory(false);
}
if (player.getPremiumItems().isEmpty())
player.sendPacket(SystemMsg.THERE_ARE_NO_MORE_VITAMIN_ITEMS_TO_BE_FOUND);
else
player.sendPacket(new ExGetPremiumItemList(player));
if (OtherConfig.GOODS_INVENTORY_ENABLED)
player.sendPacket(ExGoodsInventoryResult.CHANGED);
}
}
But if it's wrong checks, where is system message:By the looks of it, it is one of these two checks:
Probably in the GameServer Console window.But if it's wrong checks, where is system message:
"[RequestWithDrawPremiumItem] Incorrect owner, Player: "
and
"[RequestWithDrawPremiumItem] Player: " + player.getName() + " try to get item with empty list!"
Game Server console is clear, no problem.Probably in the GameServer Console window.
Game Server console is clear, no problem.
Ok, I comment this checks and then check
Посмотреть вложение 52079
char_id проверьте, у меня он всегда равен 0 при расшифровке пакета.
@Override
public void readImpl() {
_itemId = readInt();
readInt(); // 0x00
_itemCount = readLong();
}
It is the same, you just don't have the charId field set up, which is the same as removing all parts of the code that use charId.Код:@Override public void readImpl() { _itemId = readInt(); readInt(); // 0x00 _itemCount = readLong(); }
this is how it should be. Further by myself
public class RequestWithDrawPremiumItem implements ClientPacket
{
private int _itemNum;
// private int _charId;
private long _itemCount;
@Override
public void read(ReadablePacket packet)
{
_itemNum = packet.readInt();
packet.readInt(); // 0x00
_itemCount = packet.readLong();
}
@Override
public void run(GameClient client)
{
final Player player = client.getPlayer();
if ((player == null) || (_itemCount <= 0))
{
return;
}
// else if (player.getObjectId() != _charId)
// {
// Util.handleIllegalPlayerAction(player, "[RequestWithDrawPremiumItem] Incorrect owner, Player: " + player.getName(), Config.DEFAULT_PUNISH);
// return;
// }
else if (player.getPremiumItemList().isEmpty())
{
Util.handleIllegalPlayerAction(player, "[RequestWithDrawPremiumItem] Player: " + player.getName() + " try to get item with empty list!", Config.DEFAULT_PUNISH);
return;
}
else if ((player.getWeightPenalty() >= 3) || !player.isInventoryUnder90(false))
{
player.sendPacket(SystemMessageId.YOU_CANNOT_RECEIVE_THE_DIMENSIONAL_ITEM_BECAUSE_YOU_HAVE_EXCEED_YOUR_INVENTORY_WEIGHT_QUANTITY_LIMIT);
return;
}
else if (player.isProcessingTransaction())
{
player.sendPacket(SystemMessageId.ITEMS_FROM_GAME_ASSISTANTS_CANNOT_BE_EXCHANGED);
return;
}
final PremiumItem item = player.getPremiumItemList().get(_itemNum);
if ((item == null) || (item.getCount() < _itemCount))
{
return;
}
final long itemsLeft = (item.getCount() - _itemCount);
player.addItem("PremiumItem", item.getItemId(), _itemCount, player.getTarget(), true);
if (itemsLeft > 0)
{
item.updateCount(itemsLeft);
player.updatePremiumItem(_itemNum, itemsLeft);
}
else
{
player.getPremiumItemList().remove(_itemNum);
player.deletePremiumItem(_itemNum);
}
if (player.getPremiumItemList().isEmpty())
{
player.sendPacket(SystemMessageId.THERE_ARE_NO_MORE_DIMENSIONAL_ITEMS_TO_BE_FOUND);
}
else
{
player.sendPacket(new ExGetPremiumItemList(player));
}
}
}
Еще надо проверить импорты и переустановить виндуГде-то стоит защита bypass-ов и из-за этого сообщение выдаёт
Отключишь её и всё будет ок
Сталкнулся с аналогичной проблемой, только сборка Shinemaker, этот код туда вставляю, не могу скомпилировать.
/*
* This file is part of the L2J Mobius project.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package org.l2jmobius.gameserver.network.clientpackets;
import org.l2jmobius.Config;
import org.l2jmobius.gameserver.model.PremiumItem;
import org.l2jmobius.gameserver.model.actor.Player;
import org.l2jmobius.gameserver.network.SystemMessageId;
import org.l2jmobius.gameserver.network.serverpackets.ExGetPremiumItemList;
import org.l2jmobius.gameserver.util.Util;
/**
* @author Gnacik
*/
public class RequestWithDrawPremiumItem extends ClientPacket
{
private int _itemNum;
//private int _charId;
private long _itemCount;
@Override
protected void readImpl()
{
_itemNum = readInt();
readInt(); // 0
_itemCount = readLong();
}
@Override
protected void runImpl()
{
final Player player = getPlayer();
if (player == null)
{
return;
}
else if (_itemCount <= 0)
{
return;
}
// else if (player.getObjectId() != _charId)
// {
// Util.handleIllegalPlayerAction(player, "[RequestWithDrawPremiumItem] Incorrect owner, Player: " + player.getName(), Config.DEFAULT_PUNISH);
// return;
// }
else if (player.getPremiumItemList().isEmpty())
{
Util.handleIllegalPlayerAction(player, "[RequestWithDrawPremiumItem] Player: " + player.getName() + " try to get item with empty list!", Config.DEFAULT_PUNISH);
return;
}
else if ((player.getWeightPenalty() >= 3) || !player.isInventoryUnder90(false))
{
player.sendPacket(SystemMessageId.YOU_CANNOT_RECEIVE_THE_DIMENSIONAL_ITEM_BECAUSE_YOU_HAVE_EXCEED_YOUR_INVENTORY_WEIGHT_QUANTITY_LIMIT);
return;
}
else if (player.isProcessingTransaction())
{
player.sendPacket(SystemMessageId.ITEMS_FROM_GAME_ASSISTANTS_CANNOT_BE_EXCHANGED);
return;
}
final PremiumItem item = player.getPremiumItemList().get(_itemNum);
if (item == null)
{
return;
}
else if (item.getCount() < _itemCount)
{
return;
}
final long itemsLeft = (item.getCount() - _itemCount);
player.addItem("PremiumItem", item.getItemId(), _itemCount, player.getTarget(), true);
if (itemsLeft > 0)
{
item.updateCount(itemsLeft);
player.updatePremiumItem(_itemNum, itemsLeft);
}
else
{
player.getPremiumItemList().remove(_itemNum);
player.deletePremiumItem(_itemNum);
}
if (player.getPremiumItemList().isEmpty())
{
player.sendPacket(SystemMessageId.THERE_ARE_NO_MORE_DIMENSIONAL_ITEMS_TO_BE_FOUND);
}
else
{
player.sendPacket(new ExGetPremiumItemList(player));
}
}
}
Спасибо, скомпилировал, сейчас буду пробовать ) Все заработало спасибо !Как всё сложно у вас, попробуйте этот код.
Java:/* * This file is part of the L2J Mobius project. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ package org.l2jmobius.gameserver.network.clientpackets; import org.l2jmobius.Config; import org.l2jmobius.gameserver.model.PremiumItem; import org.l2jmobius.gameserver.model.actor.Player; import org.l2jmobius.gameserver.network.SystemMessageId; import org.l2jmobius.gameserver.network.serverpackets.ExGetPremiumItemList; import org.l2jmobius.gameserver.util.Util; /** * @author Gnacik */ public class RequestWithDrawPremiumItem extends ClientPacket { private int _itemNum; //private int _charId; private long _itemCount; @Override protected void readImpl() { _itemNum = readInt(); readInt(); // 0 _itemCount = readLong(); } @Override protected void runImpl() { final Player player = getPlayer(); if (player == null) { return; } else if (_itemCount <= 0) { return; } // else if (player.getObjectId() != _charId) // { // Util.handleIllegalPlayerAction(player, "[RequestWithDrawPremiumItem] Incorrect owner, Player: " + player.getName(), Config.DEFAULT_PUNISH); // return; // } else if (player.getPremiumItemList().isEmpty()) { Util.handleIllegalPlayerAction(player, "[RequestWithDrawPremiumItem] Player: " + player.getName() + " try to get item with empty list!", Config.DEFAULT_PUNISH); return; } else if ((player.getWeightPenalty() >= 3) || !player.isInventoryUnder90(false)) { player.sendPacket(SystemMessageId.YOU_CANNOT_RECEIVE_THE_DIMENSIONAL_ITEM_BECAUSE_YOU_HAVE_EXCEED_YOUR_INVENTORY_WEIGHT_QUANTITY_LIMIT); return; } else if (player.isProcessingTransaction()) { player.sendPacket(SystemMessageId.ITEMS_FROM_GAME_ASSISTANTS_CANNOT_BE_EXCHANGED); return; } final PremiumItem item = player.getPremiumItemList().get(_itemNum); if (item == null) { return; } else if (item.getCount() < _itemCount) { return; } final long itemsLeft = (item.getCount() - _itemCount); player.addItem("PremiumItem", item.getItemId(), _itemCount, player.getTarget(), true); if (itemsLeft > 0) { item.updateCount(itemsLeft); player.updatePremiumItem(_itemNum, itemsLeft); } else { player.getPremiumItemList().remove(_itemNum); player.deletePremiumItem(_itemNum); } if (player.getPremiumItemList().isEmpty()) { player.sendPacket(SystemMessageId.THERE_ARE_NO_MORE_DIMENSIONAL_ITEMS_TO_BE_FOUND); } else { player.sendPacket(new ExGetPremiumItemList(player)); } } }
We use cookies and similar technologies for the following purposes:
Do you accept cookies and these technologies?
We use cookies and similar technologies for the following purposes:
Do you accept cookies and these technologies?