forked from MagicBane/Server
99 lines
3.5 KiB
Java
99 lines
3.5 KiB
Java
// • ▌ ▄ ·. ▄▄▄· ▄▄ • ▪ ▄▄· ▄▄▄▄· ▄▄▄· ▐▄▄▄ ▄▄▄ .
|
|
// ·██ ▐███▪▐█ ▀█ ▐█ ▀ ▪██ ▐█ ▌▪▐█ ▀█▪▐█ ▀█ •█▌ ▐█▐▌·
|
|
// ▐█ ▌▐▌▐█·▄█▀▀█ ▄█ ▀█▄▐█·██ ▄▄▐█▀▀█▄▄█▀▀█ ▐█▐ ▐▌▐▀▀▀
|
|
// ██ ██▌▐█▌▐█ ▪▐▌▐█▄▪▐█▐█▌▐███▌██▄▪▐█▐█ ▪▐▌██▐ █▌▐█▄▄▌
|
|
// ▀▀ █▪▀▀▀ ▀ ▀ ·▀▀▀▀ ▀▀▀·▀▀▀ ·▀▀▀▀ ▀ ▀ ▀▀ █▪ ▀▀▀
|
|
// Magicbane Emulator Project © 2013 - 2022
|
|
// www.magicbane.com
|
|
|
|
|
|
package engine.db.handlers;
|
|
|
|
import engine.gameManager.DbManager;
|
|
import engine.objects.SkillReq;
|
|
import engine.powers.PowersBase;
|
|
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 dbSkillReqHandler extends dbHandlerBase {
|
|
|
|
public dbSkillReqHandler() {
|
|
this.localClass = SkillReq.class;
|
|
this.localObjectType = engine.Enum.GameObjectType.valueOf(this.localClass.getSimpleName());
|
|
}
|
|
|
|
public static ArrayList<PowersBase> getAllPowersBase() {
|
|
|
|
ArrayList<PowersBase> powerBaseList = new ArrayList<>();
|
|
|
|
try (Connection connection = DbManager.getConnection();
|
|
PreparedStatement preparedStatement = connection.prepareStatement("SELECT * FROM static_power_powerbase")) {
|
|
|
|
ResultSet rs = preparedStatement.executeQuery();
|
|
|
|
while (rs.next()) {
|
|
PowersBase toAdd = new PowersBase(rs);
|
|
powerBaseList.add(toAdd);
|
|
}
|
|
|
|
} catch (SQLException e) {
|
|
Logger.error(e);
|
|
}
|
|
|
|
return powerBaseList;
|
|
}
|
|
|
|
public static void getFailConditions(HashMap<String, PowersBase> powers) {
|
|
|
|
try (Connection connection = DbManager.getConnection();
|
|
PreparedStatement preparedStatement = connection.prepareStatement("SELECT IDString, type FROM static_power_failcondition where powerOrEffect = 'Power'")) {
|
|
|
|
ResultSet rs = preparedStatement.executeQuery();
|
|
|
|
while (rs.next()) {
|
|
String type = rs.getString("type");
|
|
String IDString = rs.getString("IDString");
|
|
PowersBase pb = powers.get(IDString);
|
|
|
|
if (pb != null)
|
|
switch (type) {
|
|
case "CastSpell":
|
|
pb.cancelOnCastSpell = true;
|
|
break;
|
|
case "TakeDamage":
|
|
pb.cancelOnTakeDamage = true;
|
|
break;
|
|
}
|
|
}
|
|
} catch (SQLException e) {
|
|
Logger.error(e);
|
|
}
|
|
}
|
|
|
|
public ArrayList<SkillReq> GET_REQS_FOR_RUNE(final int objectUUID) {
|
|
|
|
ArrayList<SkillReq> skillReqsList = new ArrayList<>();
|
|
|
|
try (Connection connection = DbManager.getConnection();
|
|
PreparedStatement preparedStatement = connection.prepareStatement("SELECT * FROM `static_skill_skillreq` WHERE `runeID`=?")) {
|
|
|
|
preparedStatement.setInt(1, objectUUID);
|
|
|
|
ResultSet rs = preparedStatement.executeQuery();
|
|
skillReqsList = getObjectsFromRs(rs, 5);
|
|
|
|
} catch (SQLException e) {
|
|
Logger.error(e);
|
|
}
|
|
|
|
return skillReqsList;
|
|
}
|
|
|
|
}
|