/* * 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.commons.database.DatabaseFactory; import silentium.gameserver.handler.IAdminCommandHandler; import silentium.gameserver.model.actor.instance.L2PcInstance; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; public class AdminRepairChar implements IAdminCommandHandler { private static final Logger _log = LoggerFactory.getLogger(AdminRepairChar.class.getName()); private static final String[] ADMIN_COMMANDS = { "admin_restore", "admin_repair" }; @Override public boolean useAdminCommand(final String command, final L2PcInstance activeChar) { handleRepair(command); return true; } @Override public String[] getAdminCommandList() { return ADMIN_COMMANDS; } private static void handleRepair(final String command) { final String[] parts = command.split(" "); if (parts.length != 2) return; try (Connection con = DatabaseFactory.getConnection()) { PreparedStatement statement = con.prepareStatement("UPDATE characters SET x=-84318, y=244579, z=-3730 WHERE char_name=?"); statement.setString(1, parts[1]); statement.execute(); statement.close(); statement = con.prepareStatement("SELECT obj_id FROM characters where char_name=?"); statement.setString(1, parts[1]); final ResultSet rset = statement.executeQuery(); int objId = 0; if (rset.next()) { objId = rset.getInt(1); } rset.close(); statement.close(); if (objId == 0) { con.close(); return; } statement = con.prepareStatement("DELETE FROM character_shortcuts WHERE char_obj_id=?"); statement.setInt(1, objId); statement.execute(); statement.close(); statement = con.prepareStatement("UPDATE items SET loc=\"INVENTORY\" WHERE owner_id=?"); statement.setInt(1, objId); statement.execute(); statement.close(); } catch (Exception e) { _log.warn("could not repair char:", e); } } }