/*
* 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 com.l2jserver.gameserver.network.clientpackets;
import static com.l2jserver.gameserver.model.actor.L2Npc.INTERACTION_DISTANCE;
import java.util.logging.Logger;
import javolution.util.FastSet;
import com.l2jserver.Config;
import com.l2jserver.gameserver.model.ItemRequest;
import com.l2jserver.gameserver.model.L2Object;
import com.l2jserver.gameserver.model.L2World;
import com.l2jserver.gameserver.model.TradeList;
import com.l2jserver.gameserver.model.actor.instance.L2PcInstance;
import com.l2jserver.gameserver.network.serverpackets.ActionFailed;
import com.l2jserver.gameserver.util.Util;
/**
* This class ...
*
* @version $Revision: 1.2.2.1.2.5 $ $Date: 2005/03/27 15:29:30 $
*/
public final class RequestPrivateStoreBuy extends L2GameClientPacket
{
private static final String _C__83_REQUESTPRIVATESTOREBUY = "[C] 83 RequestPrivateStoreBuy";
private static Logger _log = Logger.getLogger(RequestPrivateStoreBuy.class.getName());
private static final int BATCH_LENGTH = 20; // length of the one item
private int _storePlayerId;
private FastSet<ItemRequest> _items = null;
@Override
protected void readImpl()
{
_storePlayerId = readD();
int count = readD();
if (count <= 0 || count > Config.MAX_ITEM_IN_PACKET || count * BATCH_LENGTH != _buf.remaining())
{
return;
}
_items = FastSet.newInstance();
for (int i = 0; i < count; i++)
{
int objectId = readD();
long cnt = readQ();
long price = readQ();
if (objectId < 1 || cnt < 1 || price < 0)
{
_items = null;
return;
}
_items.add(new ItemRequest(objectId, cnt, price));
}
}
@Override
protected void runImpl()
{
L2PcInstance player = getClient().getActiveChar();
if (player == null)
return;
if (_items == null)
{
sendPacket(ActionFailed.STATIC_PACKET);
return;
}
if (!getClient().getFloodProtectors().getTransaction().tryPerformAction("privatestorebuy"))
{
player.sendMessage("You buying items too fast.");
return;
}
L2Object object = L2World.getInstance().getPlayer(_storePlayerId);
if (object == null)
return;
if (player.isCursedWeaponEquipped())
return;
L2PcInstance storePlayer = (L2PcInstance) object;
if (!player.isInsideRadius(storePlayer, INTERACTION_DISTANCE, true, false))
return;
if (player.getInstanceId() != storePlayer.getInstanceId() && player.getInstanceId() != -1)
return;
if (!(storePlayer.getPrivateStoreType() == L2PcInstance.STORE_PRIVATE_SELL || storePlayer.getPrivateStoreType() == L2PcInstance.STORE_PRIVATE_PACKAGE_SELL))
return;
TradeList storeList = storePlayer.getSellList();
if (storeList == null)
return;
if (!player.getAccessLevel().allowTransaction())
{
player.sendMessage("Transactions are disable for your Access Level");
sendPacket(ActionFailed.STATIC_PACKET);
return;
}
if (storePlayer.getPrivateStoreType() == L2PcInstance.STORE_PRIVATE_PACKAGE_SELL)
{
if (storeList.getItemCount() > _items.size())
{
String msgErr = "[RequestPrivateStoreBuy] player " + getClient().getActiveChar().getName() + " tried to buy less items than sold by package-sell, ban this player for bot usage!";
Util.handleIllegalPlayerAction(getClient().getActiveChar(), msgErr, Config.DEFAULT_PUNISH);
return;
}
}
int result = storeList.privateStoreBuy(player, _items);
if (result > 0)
{
sendPacket(ActionFailed.STATIC_PACKET);
if (result > 1)
_log.warning("PrivateStore buy has failed due to invalid list or request. Player: " + player.getName() + ", Private store of: " + storePlayer.getName());
return;
}
if (storeList.getItemCount() == 0)
{
storePlayer.setPrivateStoreType(L2PcInstance.STORE_PRIVATE_NONE);
storePlayer.broadcastUserInfo();
}
/* Lease holders are currently not implemented
else if (_seller != null)
{
// lease shop sell
L2MerchantInstance seller = (L2MerchantInstance)_seller;
L2ItemInstance ladena = seller.getLeaseAdena();
for (TradeItem ti : buyerlist) {
L2ItemInstance li = seller.getLeaseItemByObjectId(ti.getObjectId());
if (li == null) {
if (ti.getObjectId() == ladena.getObjectId())
{
buyer.addAdena(ti.getCount());
ladena.setCount(ladena.getCount()-ti.getCount());
ladena.updateDatabase();
}
continue;
}
int cnt = li.getCount();
if (cnt < ti.getCount())
ti.setCount(cnt);
if (ti.getCount() <= 0)
continue;
L2ItemInstance inst = ItemTable.getInstance().createItem(li.getItemId());
inst.setCount(ti.getCount());
inst.setEnchantLevel(li.getEnchantLevel());
buyer.getInventory().addItem(inst);
li.setCount(li.getCount()-ti.getCount());
li.updateDatabase();
ladena.setCount(ladena.getCount()+ti.getCount()*ti.getOwnersPrice());
ladena.updateDatabase();
}
}*/
}
@Override
public String getType()
{
return _C__83_REQUESTPRIVATESTOREBUY;
}
@Override
protected void cleanUp()
{
FastSet.recycle(_items);
}
@Override
protected boolean triggersOnActionRequest()
{
return false;
}
}