/* * This file is part of aion-unique <aion-unique.org>. * * aion-unique 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. * * aion-unique 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 aion-unique. If not, see <http://www.gnu.org/licenses/>. */ package mysql5; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import com.aionemu.commons.database.DB; import com.aionemu.commons.database.IUStH; import com.aionemu.commons.database.ParamReadStH; import com.aionemu.gameserver.dao.AbyssRankDAO; import com.aionemu.gameserver.model.gameobjects.PersistentState; import com.aionemu.gameserver.model.gameobjects.player.AbyssRank; import com.aionemu.gameserver.model.gameobjects.player.Player; /** * @author ATracer * */ public class MySQL5AbyssRankDAO extends AbyssRankDAO { public static final String SELECT_QUERY = "SELECT `ap`, `rank`, `all_kill`, `max_rank` FROM `abyss_rank` WHERE `player_id`=?"; public static final String INSERT_QUERY = "INSERT INTO `abyss_rank` (`player_id`, `ap`, `rank`, `all_kill`, `max_rank`) VALUES(?,?,?,?,?)"; public static final String UPDATE_QUERY = "UPDATE abyss_rank SET ap=?, rank=?, all_kill=?, max_rank=? WHERE player_id=?"; @Override public void loadAbyssRank(final Player player) { DB.select(SELECT_QUERY, new ParamReadStH() { @Override public void setParams(PreparedStatement stmt) throws SQLException { stmt.setInt(1, player.getObjectId()); } @Override public void handleRead(ResultSet rset) throws SQLException { if(rset.next()) { int ap = rset.getInt("ap"); int rank = rset.getInt("rank"); int all_kill = rset.getInt("all_kill"); int max_rank = rset.getInt("max_rank"); AbyssRank abyssRank = new AbyssRank(ap, rank, all_kill, max_rank); abyssRank.setPersistentState(PersistentState.UPDATED); player.setAbyssRank(abyssRank); } else { AbyssRank abyssRank = new AbyssRank(0, 1, 0, 1); abyssRank.setPersistentState(PersistentState.NEW); player.setAbyssRank(abyssRank); } } }); } @Override public boolean storeAbyssRank(Player player) { AbyssRank rank = player.getAbyssRank(); boolean result = false; switch(rank.getPersistentState()) { case NEW: result = addRank(player.getObjectId(), rank); break; case UPDATE_REQUIRED: result = updateRank(player.getObjectId(), rank); break; } rank.setPersistentState(PersistentState.UPDATED); return result; } /** * @param objectId * @param rank * @return */ private boolean addRank(final int objectId, final AbyssRank rank) { return DB.insertUpdate(INSERT_QUERY, new IUStH() { @Override public void handleInsertUpdate(PreparedStatement stmt) throws SQLException { stmt.setInt(1, objectId); stmt.setInt(2, rank.getAp()); stmt.setInt(3, rank.getRank().getId()); stmt.setInt(4, rank.getAllKill()); stmt.setInt(5, rank.getMaxRank()); stmt.execute(); } }); } /** * @param objectId * @param rank * @return */ private boolean updateRank(final int objectId, final AbyssRank rank) { return DB.insertUpdate(UPDATE_QUERY, new IUStH() { @Override public void handleInsertUpdate(PreparedStatement stmt) throws SQLException { stmt.setInt(1, rank.getAp()); stmt.setInt(2, rank.getRank().getId()); stmt.setInt(3, rank.getAllKill()); stmt.setInt(4, rank.getMaxRank()); stmt.setInt(5, objectId); stmt.execute(); } }); } @Override public boolean supports(String databaseName, int majorVersion, int minorVersion) { return MySQL5DAOUtils.supports(databaseName, majorVersion, minorVersion); } }