Prime shop slot validation tempfix.

Contributed by Sero.
This commit is contained in:
MobiusDevelopment 2022-03-08 22:50:48 +00:00
parent 7e09528fc1
commit 9fa8cb6fba
21 changed files with 258 additions and 90 deletions

View File

@ -73,8 +73,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final PrimeShopGroup item = PrimeShopData.getInstance().getItem(_brId);
if (validatePlayer(item, _count, player))
{
final int price = (item.getPrice() * _count);
final int paymentId = validatePaymentId(item, price);
final int price = item.getPrice() * _count;
final int paymentId = validatePaymentId(item);
if (paymentId < 0)
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.LACK_OF_POINT));
@ -194,7 +194,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
@ -209,7 +217,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
return true;
}
private static int validatePaymentId(PrimeShopGroup item, long amount)
private static int validatePaymentId(PrimeShopGroup item)
{
switch (item.getPaymentType())
{

View File

@ -73,8 +73,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final PrimeShopGroup item = PrimeShopData.getInstance().getItem(_brId);
if (validatePlayer(item, _count, player))
{
final int price = (item.getPrice() * _count);
final int paymentId = validatePaymentId(item, price);
final int price = item.getPrice() * _count;
final int paymentId = validatePaymentId(item);
if (paymentId < 0)
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.LACK_OF_POINT));
@ -194,7 +194,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
@ -209,7 +217,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
return true;
}
private static int validatePaymentId(PrimeShopGroup item, long amount)
private static int validatePaymentId(PrimeShopGroup item)
{
switch (item.getPaymentType())
{

View File

@ -73,8 +73,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final PrimeShopGroup item = PrimeShopData.getInstance().getItem(_brId);
if (validatePlayer(item, _count, player))
{
final int price = (item.getPrice() * _count);
final int paymentId = validatePaymentId(item, price);
final int price = item.getPrice() * _count;
final int paymentId = validatePaymentId(item);
if (paymentId < 0)
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.LACK_OF_POINT));
@ -194,7 +194,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
@ -209,7 +217,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
return true;
}
private static int validatePaymentId(PrimeShopGroup item, long amount)
private static int validatePaymentId(PrimeShopGroup item)
{
switch (item.getPaymentType())
{

View File

@ -73,8 +73,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final PrimeShopGroup item = PrimeShopData.getInstance().getItem(_brId);
if (validatePlayer(item, _count, player))
{
final int price = (item.getPrice() * _count);
final int paymentId = validatePaymentId(item, price);
final int price = item.getPrice() * _count;
final int paymentId = validatePaymentId(item);
if (paymentId < 0)
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.LACK_OF_POINT));
@ -194,7 +194,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
@ -209,7 +217,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
return true;
}
private static int validatePaymentId(PrimeShopGroup item, long amount)
private static int validatePaymentId(PrimeShopGroup item)
{
switch (item.getPaymentType())
{

View File

@ -73,8 +73,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final PrimeShopGroup item = PrimeShopData.getInstance().getItem(_brId);
if (validatePlayer(item, _count, player))
{
final int price = (item.getPrice() * _count);
final int paymentId = validatePaymentId(item, price);
final int price = item.getPrice() * _count;
final int paymentId = validatePaymentId(item);
if (paymentId < 0)
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.LACK_OF_POINT));
@ -194,7 +194,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
@ -209,7 +217,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
return true;
}
private static int validatePaymentId(PrimeShopGroup item, long amount)
private static int validatePaymentId(PrimeShopGroup item)
{
switch (item.getPaymentType())
{

View File

@ -73,8 +73,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final PrimeShopGroup item = PrimeShopData.getInstance().getItem(_brId);
if (validatePlayer(item, _count, player))
{
final int price = (item.getPrice() * _count);
final int paymentId = validatePaymentId(item, price);
final int price = item.getPrice() * _count;
final int paymentId = validatePaymentId(item);
if (paymentId < 0)
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.LACK_OF_POINT));
@ -194,7 +194,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
@ -209,7 +217,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
return true;
}
private static int validatePaymentId(PrimeShopGroup item, long amount)
private static int validatePaymentId(PrimeShopGroup item)
{
switch (item.getPaymentType())
{

View File

@ -73,8 +73,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final PrimeShopGroup item = PrimeShopData.getInstance().getItem(_brId);
if (validatePlayer(item, _count, player))
{
final int price = (item.getPrice() * _count);
final int paymentId = validatePaymentId(item, price);
final int price = item.getPrice() * _count;
final int paymentId = validatePaymentId(item);
if (paymentId < 0)
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.LACK_OF_POINT));
@ -194,7 +194,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
@ -209,7 +217,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
return true;
}
private static int validatePaymentId(PrimeShopGroup item, long amount)
private static int validatePaymentId(PrimeShopGroup item)
{
switch (item.getPaymentType())
{

View File

@ -73,8 +73,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final PrimeShopGroup item = PrimeShopData.getInstance().getItem(_brId);
if (validatePlayer(item, _count, player))
{
final int price = (item.getPrice() * _count);
final int paymentId = validatePaymentId(item, price);
final int price = item.getPrice() * _count;
final int paymentId = validatePaymentId(item);
if (paymentId < 0)
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.LACK_OF_POINT));
@ -194,7 +194,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
@ -209,7 +217,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
return true;
}
private static int validatePaymentId(PrimeShopGroup item, long amount)
private static int validatePaymentId(PrimeShopGroup item)
{
switch (item.getPaymentType())
{

View File

@ -73,8 +73,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final PrimeShopGroup item = PrimeShopData.getInstance().getItem(_brId);
if (validatePlayer(item, _count, player))
{
final int price = (item.getPrice() * _count);
final int paymentId = validatePaymentId(item, price);
final int price = item.getPrice() * _count;
final int paymentId = validatePaymentId(item);
if (paymentId < 0)
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.LACK_OF_POINT));
@ -194,7 +194,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
@ -209,7 +217,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
return true;
}
private static int validatePaymentId(PrimeShopGroup item, long amount)
private static int validatePaymentId(PrimeShopGroup item)
{
switch (item.getPaymentType())
{

View File

@ -73,8 +73,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final PrimeShopGroup item = PrimeShopData.getInstance().getItem(_brId);
if (validatePlayer(item, _count, player))
{
final int price = (item.getPrice() * _count);
final int paymentId = validatePaymentId(item, price);
final int price = item.getPrice() * _count;
final int paymentId = validatePaymentId(item);
if (paymentId < 0)
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.LACK_OF_POINT));
@ -194,7 +194,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
@ -209,7 +217,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
return true;
}
private static int validatePaymentId(PrimeShopGroup item, long amount)
private static int validatePaymentId(PrimeShopGroup item)
{
switch (item.getPaymentType())
{

View File

@ -73,8 +73,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final PrimeShopGroup item = PrimeShopData.getInstance().getItem(_brId);
if (validatePlayer(item, _count, player))
{
final int price = (item.getPrice() * _count);
final int paymentId = validatePaymentId(item, price);
final int price = item.getPrice() * _count;
final int paymentId = validatePaymentId(item);
if (paymentId < 0)
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.LACK_OF_POINT));
@ -194,7 +194,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
@ -209,7 +217,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
return true;
}
private static int validatePaymentId(PrimeShopGroup item, long amount)
private static int validatePaymentId(PrimeShopGroup item)
{
switch (item.getPaymentType())
{

View File

@ -78,7 +78,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
{
boolean hasItems = true;
// First loop to validate all items
// First loop to validate all items.
for (ItemHolder itemHolder : validatePaymentId(item))
{
final int paymentId = itemHolder.getId();
@ -94,8 +94,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
hasItems = false;
}
}
else
{ // this is always 0
else // This is always 0.
{
if (player.getPrimePoints() < price)
{
hasItems = false;
@ -111,7 +111,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
}
// Second loop, only if all criteria has been met!
// this should always be reached if player has all the coins needed for the purchase
// This should always be reached if player has all the coins needed for the purchase.
for (ItemHolder itemHolder : validatePaymentId(item))
{
final int paymentId = itemHolder.getId();
@ -233,7 +233,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;

View File

@ -78,7 +78,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
{
boolean hasItems = true;
// First loop to validate all items
// First loop to validate all items.
for (ItemHolder itemHolder : validatePaymentId(item))
{
final int paymentId = itemHolder.getId();
@ -94,8 +94,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
hasItems = false;
}
}
else
{ // this is always 0
else // This is always 0.
{
if (player.getPrimePoints() < price)
{
hasItems = false;
@ -111,7 +111,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
}
// Second loop, only if all criteria has been met!
// this should always be reached if player has all the coins needed for the purchase
// This should always be reached if player has all the coins needed for the purchase.
for (ItemHolder itemHolder : validatePaymentId(item))
{
final int paymentId = itemHolder.getId();
@ -233,7 +233,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;

View File

@ -78,7 +78,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
{
boolean hasItems = true;
// First loop to validate all items
// First loop to validate all items.
for (ItemHolder itemHolder : validatePaymentId(item))
{
final int paymentId = itemHolder.getId();
@ -94,8 +94,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
hasItems = false;
}
}
else
{ // this is always 0
else // This is always 0.
{
if (player.getPrimePoints() < price)
{
hasItems = false;
@ -111,7 +111,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
}
// Second loop, only if all criteria has been met!
// this should always be reached if player has all the coins needed for the purchase
// This should always be reached if player has all the coins needed for the purchase.
for (ItemHolder itemHolder : validatePaymentId(item))
{
final int paymentId = itemHolder.getId();
@ -233,7 +233,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;

View File

@ -78,7 +78,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
{
boolean hasItems = true;
// First loop to validate all items
// First loop to validate all items.
for (ItemHolder itemHolder : validatePaymentId(item))
{
final int paymentId = itemHolder.getId();
@ -94,8 +94,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
hasItems = false;
}
}
else
{ // this is always 0
else // This is always 0.
{
if (player.getPrimePoints() < price)
{
hasItems = false;
@ -111,7 +111,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
}
// Second loop, only if all criteria has been met!
// this should always be reached if player has all the coins needed for the purchase
// This should always be reached if player has all the coins needed for the purchase.
for (ItemHolder itemHolder : validatePaymentId(item))
{
final int paymentId = itemHolder.getId();
@ -233,7 +233,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;

View File

@ -78,7 +78,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
{
boolean hasItems = true;
// First loop to validate all items
// First loop to validate all items.
for (ItemHolder itemHolder : validatePaymentId(item))
{
final int paymentId = itemHolder.getId();
@ -94,8 +94,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
hasItems = false;
}
}
else
{ // this is always 0
else // This is always 0.
{
if (player.getPrimePoints() < price)
{
hasItems = false;
@ -111,7 +111,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
}
// Second loop, only if all criteria has been met!
// this should always be reached if player has all the coins needed for the purchase
// This should always be reached if player has all the coins needed for the purchase.
for (ItemHolder itemHolder : validatePaymentId(item))
{
final int paymentId = itemHolder.getId();
@ -233,7 +233,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;

View File

@ -78,7 +78,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
{
boolean hasItems = true;
// First loop to validate all items
// First loop to validate all items.
for (ItemHolder itemHolder : validatePaymentId(item))
{
final int paymentId = itemHolder.getId();
@ -94,8 +94,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
hasItems = false;
}
}
else
{ // this is always 0
else // This is always 0.
{
if (player.getPrimePoints() < price)
{
hasItems = false;
@ -111,7 +111,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
}
// Second loop, only if all criteria has been met!
// this should always be reached if player has all the coins needed for the purchase
// This should always be reached if player has all the coins needed for the purchase.
for (ItemHolder itemHolder : validatePaymentId(item))
{
final int paymentId = itemHolder.getId();
@ -233,7 +233,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;

View File

@ -73,8 +73,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final PrimeShopGroup item = PrimeShopData.getInstance().getItem(_brId);
if (validatePlayer(item, _count, player))
{
final int price = (item.getPrice() * _count);
final int paymentId = validatePaymentId(item, price);
final int price = item.getPrice() * _count;
final int paymentId = validatePaymentId(item);
if (paymentId < 0)
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.LACK_OF_POINT));
@ -194,7 +194,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
@ -209,7 +217,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
return true;
}
private static int validatePaymentId(PrimeShopGroup item, long amount)
private static int validatePaymentId(PrimeShopGroup item)
{
switch (item.getPaymentType())
{

View File

@ -73,8 +73,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final PrimeShopGroup item = PrimeShopData.getInstance().getItem(_brId);
if (validatePlayer(item, _count, player))
{
final int price = (item.getPrice() * _count);
final int paymentId = validatePaymentId(item, price);
final int price = item.getPrice() * _count;
final int paymentId = validatePaymentId(item);
if (paymentId < 0)
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.LACK_OF_POINT));
@ -208,7 +208,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
@ -250,7 +258,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
}
}
private static int validatePaymentId(PrimeShopGroup item, long amount)
private static int validatePaymentId(PrimeShopGroup item)
{
switch (item.getPaymentType())
{

View File

@ -73,8 +73,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final PrimeShopGroup item = PrimeShopData.getInstance().getItem(_brId);
if (validatePlayer(item, _count, player))
{
final int price = (item.getPrice() * _count);
final int paymentId = validatePaymentId(item, price);
final int price = item.getPrice() * _count;
final int paymentId = validatePaymentId(item);
if (paymentId < 0)
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.LACK_OF_POINT));
@ -208,7 +208,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
@ -250,7 +258,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
}
}
private static int validatePaymentId(PrimeShopGroup item, long amount)
private static int validatePaymentId(PrimeShopGroup item)
{
switch (item.getPaymentType())
{

View File

@ -73,8 +73,8 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final PrimeShopGroup item = PrimeShopData.getInstance().getItem(_brId);
if (validatePlayer(item, _count, player))
{
final int price = (item.getPrice() * _count);
final int paymentId = validatePaymentId(item, price);
final int price = item.getPrice() * _count;
final int paymentId = validatePaymentId(item);
if (paymentId < 0)
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.LACK_OF_POINT));
@ -208,7 +208,15 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
final long slots = item.getCount() * count;
if (player.getInventory().validateWeight(weight))
{
if (!player.getInventory().validateCapacity(slots))
if (item.getCount() == 1)
{
if (!player.getInventory().validateCapacity(slots))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
}
}
else if (!player.getInventory().validateCapacity(count))
{
player.sendPacket(new ExBRBuyProduct(ExBrProductReplyType.INVENTORY_OVERFLOW));
return false;
@ -250,7 +258,7 @@ public class RequestBRBuyProduct implements IClientIncomingPacket
}
}
private static int validatePaymentId(PrimeShopGroup item, long amount)
private static int validatePaymentId(PrimeShopGroup item)
{
switch (item.getPaymentType())
{