/*
* This file is part of aion-emu <aion-emu.com>.
*
* aion-emu 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-emu 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-emu. If not, see <http://www.gnu.org/licenses/>.
*/
package mysql5;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map;
import com.aionemu.commons.database.DB;
import com.aionemu.commons.database.IUStH;
import com.aionemu.commons.database.ParamReadStH;
import com.aionemu.gameserver.dao.PlayerSkillListDAO;
import com.aionemu.gameserver.model.gameobjects.PersistentState;
import com.aionemu.gameserver.model.gameobjects.player.Player;
import com.aionemu.gameserver.model.gameobjects.player.SkillList;
import com.aionemu.gameserver.model.gameobjects.player.SkillListEntry;
/**
* Created on: 15.07.2009 19:33:07
* Edited On: 13.09.2009 19:48:00
*
* @author IceReaper, orfeo087, Avol, AEJTester
*/
public class MySQL5PlayerSkillListDAO extends PlayerSkillListDAO
{
public static final String INSERT_QUERY = "INSERT INTO `player_skills` (`player_id`, `skillId`, `skillLevel`) VALUES (?,?,?)";
public static final String UPDATE_QUERY = "UPDATE `player_skills` set skillLevel=? where player_id=? AND skillId=?";
public static final String DELETE_QUERY = "DELETE FROM `player_skills` WHERE `player_id`=? AND skillId=?";
public static final String SELECT_QUERY = "SELECT `skillId`, `skillLevel` FROM `player_skills` WHERE `player_id`=?";
/** {@inheritDoc} */
@Override
public SkillList loadSkillList(final int playerId)
{
final Map<Integer, SkillListEntry> skills = new HashMap<Integer, SkillListEntry>();
DB.select(SELECT_QUERY, new ParamReadStH()
{
@Override
public void setParams(PreparedStatement stmt) throws SQLException
{
stmt.setInt(1, playerId);
}
@Override
public void handleRead(ResultSet rset) throws SQLException
{
while(rset.next())
{
int id = rset.getInt("skillId");
int lv = rset.getInt("skillLevel");
skills.put(id, new SkillListEntry(id, lv, PersistentState.UPDATED));
}
}
});
return new SkillList(skills);
}
/**
* Stores all player skills according to their persistence state
*/
@Override
public boolean storeSkills(Player player)
{
SkillListEntry[] skillsActive = player.getSkillList().getAllSkills();
SkillListEntry[] skillsDeleted = player.getSkillList().getDeletedSkills();
store(player, skillsActive);
store(player, skillsDeleted);
return true;
}
/**
*
* @param player
* @param skills
*/
private void store(Player player, SkillListEntry[] skills)
{
for(int i = 0; i < skills.length ; i++)
{
SkillListEntry skill = skills[i];
switch(skill.getPersistentState())
{
case NEW:
addSkill(player.getObjectId(), skill.getSkillId(), skill.getSkillLevel());
break;
case UPDATE_REQUIRED:
updateSkill(player.getObjectId(), skill.getSkillId(), skill.getSkillLevel());
break;
case DELETED:
deleteSkill(player.getObjectId(), skill.getSkillId());
break;
}
skill.setPersistentState(PersistentState.UPDATED);
}
}
/**
* Add a skill information into database
*
* @param playerId player object id
* @param skill skill contents.
*/
private void addSkill(final int playerId, final int skillId, final int skillLevel)
{
DB.insertUpdate(INSERT_QUERY, new IUStH() {
@Override
public void handleInsertUpdate(PreparedStatement stmt) throws SQLException
{
stmt.setInt(1, playerId);
stmt.setInt(2, skillId);
stmt.setInt(3, skillLevel);
stmt.execute();
}
});
}
/**
* Updates skill in database (after level change)
*
* @param playerId
* @param skillId
* @param skillLevel
*/
private void updateSkill(final int playerId, final int skillId, final int skillLevel)
{
DB.insertUpdate(UPDATE_QUERY, new IUStH() {
@Override
public void handleInsertUpdate(PreparedStatement stmt) throws SQLException
{
stmt.setInt(1, skillLevel);
stmt.setInt(2, playerId);
stmt.setInt(3, skillId);
stmt.execute();
}
});
}
/**
* Deletes skill from database
*
* @param playerId
* @param skillId
*/
private void deleteSkill(final int playerId, final int skillId)
{
DB.insertUpdate(DELETE_QUERY, new IUStH()
{
@Override
public void handleInsertUpdate(PreparedStatement stmt) throws SQLException
{
stmt.setInt(1, playerId);
stmt.setInt(2, skillId);
stmt.execute();
}
});
}
@Override
public boolean supports(String databaseName, int majorVersion, int minorVersion)
{
return MySQL5DAOUtils.supports(databaseName, majorVersion, minorVersion);
}
}