2011-03-19 23:39:51 +01:00
|
|
|
package com.earth2me.essentials.commands;
|
|
|
|
|
2011-07-06 02:58:59 +02:00
|
|
|
import com.earth2me.essentials.Trade;
|
2011-03-19 23:39:51 +01:00
|
|
|
import com.earth2me.essentials.User;
|
2013-06-08 23:31:19 +02:00
|
|
|
import com.earth2me.essentials.utils.NumberUtil;
|
2015-04-15 06:06:16 +02:00
|
|
|
import org.bukkit.Server;
|
|
|
|
import org.bukkit.inventory.ItemStack;
|
|
|
|
|
2013-05-05 05:13:17 +02:00
|
|
|
import java.math.BigDecimal;
|
2013-07-13 19:52:53 +02:00
|
|
|
import java.util.List;
|
2011-11-21 02:55:26 +01:00
|
|
|
import java.util.Locale;
|
2011-05-09 11:31:36 +02:00
|
|
|
import java.util.logging.Level;
|
2011-03-19 23:39:51 +01:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
import static com.earth2me.essentials.I18n.tl;
|
|
|
|
|
|
|
|
|
|
|
|
public class Commandsell extends EssentialsCommand {
|
|
|
|
public Commandsell() {
|
|
|
|
super("sell");
|
|
|
|
}
|
2011-03-19 23:39:51 +01:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
@Override
|
|
|
|
public void run(final Server server, final User user, final String commandLabel, final String[] args) throws Exception {
|
|
|
|
BigDecimal totalWorth = BigDecimal.ZERO;
|
|
|
|
String type = "";
|
|
|
|
if (args.length < 1) {
|
|
|
|
throw new NotEnoughArgumentsException();
|
|
|
|
}
|
2015-08-07 23:53:20 +02:00
|
|
|
|
|
|
|
if (args[0].equalsIgnoreCase("hand") && !user.isAuthorized("essentials.sell.hand")) {
|
|
|
|
throw new Exception(tl("sellHandPermission"));
|
|
|
|
} else if (args[0].equalsIgnoreCase("inventory") || args[0].equalsIgnoreCase("invent") || args[0].equalsIgnoreCase("all") && !user.isAuthorized("essentials.sell.bulk")) {
|
|
|
|
throw new Exception(tl("sellBulkPermission"));
|
|
|
|
}
|
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
List<ItemStack> is = ess.getItemDb().getMatching(user, args);
|
|
|
|
int count = 0;
|
2011-03-19 23:39:51 +01:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
boolean isBulk = is.size() > 1;
|
2013-07-13 19:52:53 +02:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
for (ItemStack stack : is) {
|
|
|
|
try {
|
|
|
|
if (stack.getAmount() > 0) {
|
|
|
|
totalWorth = totalWorth.add(sellItem(user, stack, args, isBulk));
|
|
|
|
stack = stack.clone();
|
|
|
|
count++;
|
|
|
|
for (ItemStack zeroStack : is) {
|
|
|
|
if (zeroStack.isSimilar(stack)) {
|
|
|
|
zeroStack.setAmount(0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (Exception e) {
|
|
|
|
if (!isBulk) {
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (count != 1) {
|
|
|
|
if (args[0].equalsIgnoreCase("blocks")) {
|
|
|
|
user.sendMessage(tl("totalWorthBlocks", type, NumberUtil.displayCurrency(totalWorth, ess)));
|
|
|
|
} else {
|
|
|
|
user.sendMessage(tl("totalWorthAll", type, NumberUtil.displayCurrency(totalWorth, ess)));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2013-07-14 02:03:08 +02:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
private BigDecimal sellItem(User user, ItemStack is, String[] args, boolean isBulkSell) throws Exception {
|
|
|
|
int amount = ess.getWorth().getAmount(ess, user, is, args, isBulkSell);
|
|
|
|
BigDecimal worth = ess.getWorth().getPrice(is);
|
2011-05-04 18:22:38 +02:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
if (worth == null) {
|
|
|
|
throw new Exception(tl("itemCannotBeSold"));
|
|
|
|
}
|
2011-03-19 23:39:51 +01:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
if (amount <= 0) {
|
|
|
|
if (!isBulkSell) {
|
|
|
|
user.sendMessage(tl("itemSold", NumberUtil.displayCurrency(BigDecimal.ZERO, ess), BigDecimal.ZERO, is.getType().toString().toLowerCase(Locale.ENGLISH), NumberUtil.displayCurrency(worth, ess)));
|
|
|
|
}
|
|
|
|
return BigDecimal.ZERO;
|
|
|
|
}
|
2011-03-19 23:39:51 +01:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
BigDecimal result = worth.multiply(BigDecimal.valueOf(amount));
|
2011-03-19 23:39:51 +01:00
|
|
|
|
2015-04-15 06:06:16 +02:00
|
|
|
//TODO: Prices for Enchantments
|
|
|
|
final ItemStack ris = is.clone();
|
|
|
|
ris.setAmount(amount);
|
|
|
|
if (!user.getBase().getInventory().containsAtLeast(ris, amount)) {
|
|
|
|
// This should never happen.
|
|
|
|
throw new IllegalStateException("Trying to remove more items than are available.");
|
|
|
|
}
|
|
|
|
user.getBase().getInventory().removeItem(ris);
|
|
|
|
user.getBase().updateInventory();
|
|
|
|
Trade.log("Command", "Sell", "Item", user.getName(), new Trade(ris, ess), user.getName(), new Trade(result, ess), user.getLocation(), ess);
|
|
|
|
user.giveMoney(result);
|
|
|
|
user.sendMessage(tl("itemSold", NumberUtil.displayCurrency(result, ess), amount, is.getType().toString().toLowerCase(Locale.ENGLISH), NumberUtil.displayCurrency(worth, ess)));
|
|
|
|
logger.log(Level.INFO, tl("itemSoldConsole", user.getDisplayName(), is.getType().toString().toLowerCase(Locale.ENGLISH), NumberUtil.displayCurrency(result, ess), amount, NumberUtil.displayCurrency(worth, ess)));
|
|
|
|
return result;
|
|
|
|
}
|
2011-03-19 23:39:51 +01:00
|
|
|
}
|