/*
* 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 silentium.scripts.handlers.admin;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import silentium.gameserver.TradeController;
import silentium.gameserver.handler.IAdminCommandHandler;
import silentium.gameserver.model.L2TradeList;
import silentium.gameserver.model.actor.instance.L2PcInstance;
import silentium.gameserver.network.clientpackets.Say2;
import silentium.gameserver.network.serverpackets.ActionFailed;
import silentium.gameserver.network.serverpackets.BuyList;
/**
* This class handles following admin commands: - gmshop = shows menu - buy id = shows shop with respective id
*/
public class AdminShop implements IAdminCommandHandler {
private static final Logger _log = LoggerFactory.getLogger(AdminShop.class.getName());
private static final String[] ADMIN_COMMANDS = { "admin_buy", "admin_gmshop" };
@Override
public boolean useAdminCommand(final String command, final L2PcInstance activeChar) {
if (command.startsWith("admin_buy")) {
try {
handleBuyRequest(activeChar, command.substring(10));
} catch (IndexOutOfBoundsException e) {
activeChar.sendChatMessage(0, Say2.ALL, "SYS", "Please specify buylist.");
}
} else if ("admin_gmshop".equals(command))
AdminHelpPage.showHelpPage(activeChar, "gmshops.htm");
return true;
}
@Override
public String[] getAdminCommandList() {
return ADMIN_COMMANDS;
}
private static void handleBuyRequest(final L2PcInstance activeChar, final String command) {
int val = -1;
try {
val = Integer.parseInt(command);
} catch (Exception e) {
_log.warn("admin buylist failed:" + command);
}
final L2TradeList list = TradeController.getInstance().getBuyList(val);
if (list != null) {
activeChar.sendPacket(new BuyList(list, activeChar.getAdena(), 0));
_log.info("GM: " + activeChar.getName() + '(' + activeChar.getObjectId() + ") opened GM shop id " + val);
} else
_log.warn("no buylist with id:" + val);
activeChar.sendPacket(ActionFailed.STATIC_PACKET);
}
}