|
|
|
// • ▌ ▄ ·. ▄▄▄· ▄▄ • ▪ ▄▄· ▄▄▄▄· ▄▄▄· ▐▄▄▄ ▄▄▄ .
|
|
|
|
// ·██ ▐███▪▐█ ▀█ ▐█ ▀ ▪██ ▐█ ▌▪▐█ ▀█▪▐█ ▀█ •█▌ ▐█▐▌·
|
|
|
|
// ▐█ ▌▐▌▐█·▄█▀▀█ ▄█ ▀█▄▐█·██ ▄▄▐█▀▀█▄▄█▀▀█ ▐█▐ ▐▌▐▀▀▀
|
|
|
|
// ██ ██▌▐█▌▐█ ▪▐▌▐█▄▪▐█▐█▌▐███▌██▄▪▐█▐█ ▪▐▌██▐ █▌▐█▄▄▌
|
|
|
|
// ▀▀ █▪▀▀▀ ▀ ▀ ·▀▀▀▀ ▀▀▀·▀▀▀ ·▀▀▀▀ ▀ ▀ ▀▀ █▪ ▀▀▀
|
|
|
|
// Magicbane Emulator Project © 2013 - 2022
|
|
|
|
// www.magicbane.com
|
|
|
|
|
|
|
|
|
|
|
|
package engine.db.handlers;
|
|
|
|
|
|
|
|
import engine.Enum;
|
|
|
|
import engine.Enum.GameObjectType;
|
|
|
|
import engine.gameManager.DbManager;
|
|
|
|
import engine.objects.AbstractGameObject;
|
|
|
|
import engine.objects.MaxSkills;
|
|
|
|
import engine.objects.SkillsBase;
|
|
|
|
import org.pmw.tinylog.Logger;
|
|
|
|
|
|
|
|
import java.sql.Connection;
|
|
|
|
import java.sql.PreparedStatement;
|
|
|
|
import java.sql.ResultSet;
|
|
|
|
import java.sql.SQLException;
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.HashMap;
|
|
|
|
|
|
|
|
public class dbSkillBaseHandler extends dbHandlerBase {
|
|
|
|
|
|
|
|
public dbSkillBaseHandler() {
|
|
|
|
this.localClass = SkillsBase.class;
|
|
|
|
this.localObjectType = Enum.GameObjectType.valueOf(this.localClass.getSimpleName());
|
|
|
|
}
|
|
|
|
|
|
|
|
public SkillsBase GET_BASE(final int objectUUID) {
|
|
|
|
|
|
|
|
SkillsBase skillsBase = (SkillsBase) DbManager.getFromCache(GameObjectType.SkillsBase, objectUUID);
|
|
|
|
if (skillsBase != null)
|
|
|
|
return skillsBase;
|
|
|
|
prepareCallable("SELECT * FROM static_skill_skillsbase WHERE ID = ?");
|
|
|
|
setInt(1, objectUUID);
|
|
|
|
SkillsBase sb;
|
|
|
|
sb = (SkillsBase) getObjectSingle(objectUUID);
|
|
|
|
SkillsBase.putInCache(sb);
|
|
|
|
return sb;
|
|
|
|
}
|
|
|
|
|
|
|
|
public SkillsBase GET_BASE_BY_NAME(String name) {
|
|
|
|
SkillsBase sb = SkillsBase.getFromCache(name);
|
|
|
|
if (sb != null) {
|
|
|
|
return sb;
|
|
|
|
}
|
|
|
|
prepareCallable("SELECT * FROM static_skill_skillsbase WHERE name = ?");
|
|
|
|
setString(1, name);
|
|
|
|
ArrayList<AbstractGameObject> result = getObjectList();
|
|
|
|
if (result.size() > 0) {
|
|
|
|
sb = (SkillsBase) result.get(0);
|
|
|
|
SkillsBase.putInCache(sb);
|
|
|
|
return sb;
|
|
|
|
} else {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public SkillsBase GET_BASE_BY_TOKEN(final int token) {
|
|
|
|
SkillsBase sb = SkillsBase.getFromCache(token);
|
|
|
|
if (sb != null) {
|
|
|
|
return sb;
|
|
|
|
}
|
|
|
|
|
|
|
|
prepareCallable("SELECT * FROM static_skill_skillsbase WHERE token = ?");
|
|
|
|
setInt(1, token);
|
|
|
|
ArrayList<AbstractGameObject> result = getObjectList();
|
|
|
|
if (result.size() > 0) {
|
|
|
|
sb = (SkillsBase) result.get(0);
|
|
|
|
SkillsBase.putInCache(sb);
|
|
|
|
return sb;
|
|
|
|
} else {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public void LOAD_ALL_MAX_SKILLS_FOR_CONTRACT() {
|
|
|
|
|
|
|
|
prepareCallable("SELECT * FROM `static_rune_maxskills`");
|
|
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
ResultSet rs = executeQuery();
|
|
|
|
|
|
|
|
//shrines cached in rs for easy cache on creation.
|
|
|
|
while (rs.next()) {
|
|
|
|
|
|
|
|
MaxSkills maxSKills = new MaxSkills(rs);
|
|
|
|
if (MaxSkills.MaxSkillsSet.get(maxSKills.getRuneID()) == null) {
|
|
|
|
ArrayList<MaxSkills> newMaxSkillsList = new ArrayList<>();
|
|
|
|
newMaxSkillsList.add(maxSKills);
|
|
|
|
MaxSkills.MaxSkillsSet.put(maxSKills.getRuneID(), newMaxSkillsList);
|
|
|
|
} else
|
|
|
|
MaxSkills.MaxSkillsSet.get(maxSKills.getRuneID()).add(maxSKills);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
} catch (SQLException e) {
|
|
|
|
Logger.error(e.getErrorCode() + ' ' + e.getMessage(), e);
|
|
|
|
} finally {
|
|
|
|
closeCallable();
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public void LOAD_ALL_RUNE_SKILLS() {
|
|
|
|
|
|
|
|
|
|
|
|
try (Connection connection = DbManager.getConnection();
|
|
|
|
PreparedStatement preparedStatement = connection.prepareStatement("SELECT * FROM `static_skill_skillsgranted`")) {
|
|
|
|
|
|
|
|
ResultSet rs = preparedStatement.executeQuery();
|
|
|
|
|
|
|
|
while (rs.next()) {
|
|
|
|
|
|
|
|
int runeID = rs.getInt("runeID");
|
|
|
|
int token = rs.getInt("token");
|
|
|
|
int amount = rs.getInt("amount");
|
|
|
|
|
|
|
|
if (SkillsBase.runeSkillsCache.get(runeID) == null)
|
|
|
|
SkillsBase.runeSkillsCache.put(runeID, new HashMap<>());
|
|
|
|
|
|
|
|
SkillsBase.runeSkillsCache.get(runeID).put(token, amount);
|
|
|
|
}
|
|
|
|
|
|
|
|
} catch (SQLException e) {
|
|
|
|
Logger.error(e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|