/*
* 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);
}
}
}