Essentials/Essentials/src/com/earth2me/essentials/commands/Commandsell.java

101 lines
4.0 KiB
Java
Raw Normal View History

package com.earth2me.essentials.commands;
import com.earth2me.essentials.Trade;
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;
import java.util.List;
import java.util.Locale;
import java.util.logging.Level;
2015-04-15 06:06:16 +02:00
import static com.earth2me.essentials.I18n.tl;
public class Commandsell extends EssentialsCommand {
public Commandsell() {
super("sell");
}
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();
}
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;
2015-04-15 06:06:16 +02:00
boolean isBulk = is.size() > 1;
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)));
}
}
}
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);
2015-04-15 06:06:16 +02:00
if (worth == null) {
throw new Exception(tl("itemCannotBeSold"));
}
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;
}
2015-04-15 06:06:16 +02:00
BigDecimal result = worth.multiply(BigDecimal.valueOf(amount));
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;
}
}