refactor: use try-with-resources for guild db operations
This commit is contained in:
@@ -24,33 +24,24 @@ package net.server.guild;
|
|||||||
import client.MapleCharacter;
|
import client.MapleCharacter;
|
||||||
import client.MapleClient;
|
import client.MapleClient;
|
||||||
import config.YamlConfig;
|
import config.YamlConfig;
|
||||||
|
import net.server.PlayerStorage;
|
||||||
|
import net.server.Server;
|
||||||
|
import net.server.audit.locks.MonitoredLockType;
|
||||||
|
import net.server.audit.locks.factory.MonitoredReentrantLockFactory;
|
||||||
|
import net.server.channel.Channel;
|
||||||
|
import net.server.coordinator.matchchecker.MapleMatchCheckerCoordinator;
|
||||||
|
import net.server.coordinator.world.MapleInviteCoordinator;
|
||||||
|
import net.server.coordinator.world.MapleInviteCoordinator.InviteType;
|
||||||
|
import net.server.coordinator.world.MapleInviteCoordinator.MapleInviteResult;
|
||||||
|
import tools.DatabaseConnection;
|
||||||
|
import tools.MaplePacketCreator;
|
||||||
|
|
||||||
import java.sql.Connection;
|
import java.sql.Connection;
|
||||||
import java.sql.PreparedStatement;
|
import java.sql.PreparedStatement;
|
||||||
import java.sql.ResultSet;
|
import java.sql.ResultSet;
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
import java.util.ArrayList;
|
import java.util.*;
|
||||||
import java.util.Comparator;
|
|
||||||
import java.util.LinkedHashMap;
|
|
||||||
import java.util.LinkedList;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import java.util.concurrent.locks.Lock;
|
import java.util.concurrent.locks.Lock;
|
||||||
import net.server.audit.locks.factory.MonitoredReentrantLockFactory;
|
|
||||||
|
|
||||||
import net.server.PlayerStorage;
|
|
||||||
import net.server.Server;
|
|
||||||
import net.server.channel.Channel;
|
|
||||||
import tools.DatabaseConnection;
|
|
||||||
import tools.MaplePacketCreator;
|
|
||||||
import net.server.audit.locks.MonitoredLockType;
|
|
||||||
import net.server.coordinator.world.MapleInviteCoordinator;
|
|
||||||
import net.server.coordinator.world.MapleInviteCoordinator.InviteType;
|
|
||||||
import net.server.coordinator.world.MapleInviteCoordinator.MapleInviteResult;
|
|
||||||
import net.server.coordinator.matchchecker.MapleMatchCheckerCoordinator;
|
|
||||||
|
|
||||||
public class MapleGuild {
|
public class MapleGuild {
|
||||||
|
|
||||||
@@ -61,7 +52,7 @@ public class MapleGuild {
|
|||||||
private final List<MapleGuildCharacter> members;
|
private final List<MapleGuildCharacter> members;
|
||||||
private final Lock membersLock = MonitoredReentrantLockFactory.createLock(MonitoredLockType.GUILD, true);
|
private final Lock membersLock = MonitoredReentrantLockFactory.createLock(MonitoredLockType.GUILD, true);
|
||||||
|
|
||||||
private String rankTitles[] = new String[5]; // 1 = master, 2 = jr, 5 = lowest member
|
private String[] rankTitles = new String[5]; // 1 = master, 2 = jr, 5 = lowest member
|
||||||
private String name, notice;
|
private String name, notice;
|
||||||
private int id, gp, logo, logoColor, leader, capacity, logoBG, logoBGColor, signature, allianceId;
|
private int id, gp, logo, logoColor, leader, capacity, logoBG, logoBGColor, signature, allianceId;
|
||||||
private int world;
|
private int world;
|
||||||
@@ -71,49 +62,46 @@ public class MapleGuild {
|
|||||||
public MapleGuild(int guildid, int world) {
|
public MapleGuild(int guildid, int world) {
|
||||||
this.world = world;
|
this.world = world;
|
||||||
members = new ArrayList<>();
|
members = new ArrayList<>();
|
||||||
Connection con = null;
|
|
||||||
try {
|
|
||||||
con = DatabaseConnection.getConnection();
|
|
||||||
PreparedStatement ps = con.prepareStatement("SELECT * FROM guilds WHERE guildid = " + guildid);
|
|
||||||
ResultSet rs = ps.executeQuery();
|
|
||||||
if (!rs.next()) {
|
|
||||||
id = -1;
|
|
||||||
ps.close();
|
|
||||||
rs.close();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
id = guildid;
|
|
||||||
name = rs.getString("name");
|
|
||||||
gp = rs.getInt("GP");
|
|
||||||
logo = rs.getInt("logo");
|
|
||||||
logoColor = rs.getInt("logoColor");
|
|
||||||
logoBG = rs.getInt("logoBG");
|
|
||||||
logoBGColor = rs.getInt("logoBGColor");
|
|
||||||
capacity = rs.getInt("capacity");
|
|
||||||
for (int i = 1; i <= 5; i++) {
|
|
||||||
rankTitles[i - 1] = rs.getString("rank" + i + "title");
|
|
||||||
}
|
|
||||||
leader = rs.getInt("leader");
|
|
||||||
notice = rs.getString("notice");
|
|
||||||
signature = rs.getInt("signature");
|
|
||||||
allianceId = rs.getInt("allianceId");
|
|
||||||
ps.close();
|
|
||||||
rs.close();
|
|
||||||
ps = con.prepareStatement("SELECT id, name, level, job, guildrank, allianceRank FROM characters WHERE guildid = ? ORDER BY guildrank ASC, name ASC");
|
|
||||||
ps.setInt(1, guildid);
|
|
||||||
rs = ps.executeQuery();
|
|
||||||
if (!rs.next()) {
|
|
||||||
rs.close();
|
|
||||||
ps.close();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
do {
|
|
||||||
members.add(new MapleGuildCharacter(null, rs.getInt("id"), rs.getInt("level"), rs.getString("name"), (byte) -1, world, rs.getInt("job"), rs.getInt("guildrank"), guildid, false, rs.getInt("allianceRank")));
|
|
||||||
} while (rs.next());
|
|
||||||
|
|
||||||
ps.close();
|
try (Connection con = DatabaseConnection.getConnection()) {
|
||||||
rs.close();
|
try (PreparedStatement ps = con.prepareStatement("SELECT * FROM guilds WHERE guildid = " + guildid);
|
||||||
con.close();
|
ResultSet rs = ps.executeQuery()) {
|
||||||
|
if (!rs.next()) {
|
||||||
|
id = -1;
|
||||||
|
ps.close();
|
||||||
|
rs.close();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
id = guildid;
|
||||||
|
name = rs.getString("name");
|
||||||
|
gp = rs.getInt("GP");
|
||||||
|
logo = rs.getInt("logo");
|
||||||
|
logoColor = rs.getInt("logoColor");
|
||||||
|
logoBG = rs.getInt("logoBG");
|
||||||
|
logoBGColor = rs.getInt("logoBGColor");
|
||||||
|
capacity = rs.getInt("capacity");
|
||||||
|
for (int i = 1; i <= 5; i++) {
|
||||||
|
rankTitles[i - 1] = rs.getString("rank" + i + "title");
|
||||||
|
}
|
||||||
|
leader = rs.getInt("leader");
|
||||||
|
notice = rs.getString("notice");
|
||||||
|
signature = rs.getInt("signature");
|
||||||
|
allianceId = rs.getInt("allianceId");
|
||||||
|
}
|
||||||
|
|
||||||
|
try (PreparedStatement ps = con.prepareStatement("SELECT id, name, level, job, guildrank, allianceRank FROM characters WHERE guildid = ? ORDER BY guildrank ASC, name ASC")) {
|
||||||
|
ps.setInt(1, guildid);
|
||||||
|
|
||||||
|
try (ResultSet rs = ps.executeQuery()) {
|
||||||
|
if (!rs.next()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
do {
|
||||||
|
members.add(new MapleGuildCharacter(null, rs.getInt("id"), rs.getInt("level"), rs.getString("name"), (byte) -1, world, rs.getInt("job"), rs.getInt("guildrank"), guildid, false, rs.getInt("allianceRank")));
|
||||||
|
} while (rs.next());
|
||||||
|
}
|
||||||
|
}
|
||||||
} catch (SQLException se) {
|
} catch (SQLException se) {
|
||||||
se.printStackTrace();
|
se.printStackTrace();
|
||||||
System.out.println("Unable to read guild information from sql: " + se);
|
System.out.println("Unable to read guild information from sql: " + se);
|
||||||
@@ -149,7 +137,9 @@ public class MapleGuild {
|
|||||||
synchronized (notifications) {
|
synchronized (notifications) {
|
||||||
chl = notifications.get(mgc.getChannel());
|
chl = notifications.get(mgc.getChannel());
|
||||||
}
|
}
|
||||||
if (chl != null) chl.add(mgc.getId());
|
if (chl != null) {
|
||||||
|
chl.add(mgc.getId());
|
||||||
|
}
|
||||||
//Unable to connect to Channel... error was here
|
//Unable to connect to Channel... error was here
|
||||||
}
|
}
|
||||||
} finally {
|
} finally {
|
||||||
@@ -160,8 +150,7 @@ public class MapleGuild {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void writeToDB(boolean bDisband) {
|
public void writeToDB(boolean bDisband) {
|
||||||
try {
|
try (Connection con = DatabaseConnection.getConnection()) {
|
||||||
Connection con = DatabaseConnection.getConnection();
|
|
||||||
|
|
||||||
if (!bDisband) {
|
if (!bDisband) {
|
||||||
StringBuilder builder = new StringBuilder();
|
StringBuilder builder = new StringBuilder();
|
||||||
@@ -182,17 +171,18 @@ public class MapleGuild {
|
|||||||
ps.setInt(11, capacity);
|
ps.setInt(11, capacity);
|
||||||
ps.setString(12, notice);
|
ps.setString(12, notice);
|
||||||
ps.setInt(13, this.id);
|
ps.setInt(13, this.id);
|
||||||
ps.execute();
|
ps.executeUpdate();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
PreparedStatement ps = con.prepareStatement("UPDATE characters SET guildid = 0, guildrank = 5 WHERE guildid = ?");
|
try (PreparedStatement ps = con.prepareStatement("UPDATE characters SET guildid = 0, guildrank = 5 WHERE guildid = ?")) {
|
||||||
ps.setInt(1, this.id);
|
ps.setInt(1, this.id);
|
||||||
ps.execute();
|
ps.executeUpdate();
|
||||||
ps.close();
|
}
|
||||||
ps = con.prepareStatement("DELETE FROM guilds WHERE guildid = ?");
|
|
||||||
ps.setInt(1, this.id);
|
try (PreparedStatement ps = con.prepareStatement("DELETE FROM guilds WHERE guildid = ?")) {
|
||||||
ps.execute();
|
ps.setInt(1, this.id);
|
||||||
ps.close();
|
ps.executeUpdate();
|
||||||
|
}
|
||||||
|
|
||||||
membersLock.lock();
|
membersLock.lock();
|
||||||
try {
|
try {
|
||||||
@@ -201,8 +191,6 @@ public class MapleGuild {
|
|||||||
membersLock.unlock();
|
membersLock.unlock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
con.close();
|
|
||||||
} catch (SQLException se) {
|
} catch (SQLException se) {
|
||||||
se.printStackTrace();
|
se.printStackTrace();
|
||||||
}
|
}
|
||||||
@@ -289,7 +277,9 @@ public class MapleGuild {
|
|||||||
|
|
||||||
for (MapleGuildCharacter mgc : getMembers()) {
|
for (MapleGuildCharacter mgc : getMembers()) {
|
||||||
MapleCharacter chr = ps.getCharacterById(mgc.getId());
|
MapleCharacter chr = ps.getCharacterById(mgc.getId());
|
||||||
if (chr == null || !chr.isLoggedinWorld()) continue;
|
if (chr == null || !chr.isLoggedinWorld()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
byte[] packet = MaplePacketCreator.guildNameChanged(chr.getId(), this.getName());
|
byte[] packet = MaplePacketCreator.guildNameChanged(chr.getId(), this.getName());
|
||||||
chr.getMap().broadcastMessage(chr, packet);
|
chr.getMap().broadcastMessage(chr, packet);
|
||||||
@@ -301,7 +291,9 @@ public class MapleGuild {
|
|||||||
|
|
||||||
for (MapleGuildCharacter mgc : getMembers()) {
|
for (MapleGuildCharacter mgc : getMembers()) {
|
||||||
MapleCharacter chr = ps.getCharacterById(mgc.getId());
|
MapleCharacter chr = ps.getCharacterById(mgc.getId());
|
||||||
if (chr == null || !chr.isLoggedinWorld()) continue;
|
if (chr == null || !chr.isLoggedinWorld()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
byte[] packet = MaplePacketCreator.guildMarkChanged(chr.getId(), this);
|
byte[] packet = MaplePacketCreator.guildMarkChanged(chr.getId(), this);
|
||||||
chr.getMap().broadcastMessage(chr, packet);
|
chr.getMap().broadcastMessage(chr, packet);
|
||||||
@@ -313,7 +305,9 @@ public class MapleGuild {
|
|||||||
|
|
||||||
for (MapleGuildCharacter mgc : getMembers()) {
|
for (MapleGuildCharacter mgc : getMembers()) {
|
||||||
MapleCharacter chr = ps.getCharacterById(mgc.getId());
|
MapleCharacter chr = ps.getCharacterById(mgc.getId());
|
||||||
if (chr == null || !chr.isLoggedinWorld()) continue;
|
if (chr == null || !chr.isLoggedinWorld()) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
byte[] packet = MaplePacketCreator.showGuildInfo(chr);
|
byte[] packet = MaplePacketCreator.showGuildInfo(chr);
|
||||||
chr.announce(packet);
|
chr.announce(packet);
|
||||||
@@ -381,7 +375,7 @@ public class MapleGuild {
|
|||||||
membersLock.lock();
|
membersLock.lock();
|
||||||
try {
|
try {
|
||||||
for (MapleGuildCharacter mgc : members) {
|
for (MapleGuildCharacter mgc : members) {
|
||||||
if(mgc.getCharacter() != null) {
|
if (mgc.getCharacter() != null) {
|
||||||
mgc.getCharacter().dropMessage(type, message);
|
mgc.getCharacter().dropMessage(type, message);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -431,41 +425,40 @@ public class MapleGuild {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static int createGuild(int leaderId, String name) {
|
public static int createGuild(int leaderId, String name) {
|
||||||
try {
|
try (Connection con = DatabaseConnection.getConnection()) {
|
||||||
Connection con = DatabaseConnection.getConnection();
|
|
||||||
PreparedStatement ps = con.prepareStatement("SELECT guildid FROM guilds WHERE name = ?");
|
try (PreparedStatement ps = con.prepareStatement("SELECT guildid FROM guilds WHERE name = ?")) {
|
||||||
ps.setString(1, name);
|
ps.setString(1, name);
|
||||||
ResultSet rs = ps.executeQuery();
|
try (ResultSet rs = ps.executeQuery()) {
|
||||||
if (rs.next()) {
|
if (rs.next()) {
|
||||||
ps.close();
|
return 0;
|
||||||
rs.close();
|
}
|
||||||
return 0;
|
}
|
||||||
}
|
}
|
||||||
ps.close();
|
|
||||||
rs.close();
|
|
||||||
|
|
||||||
ps = con.prepareStatement("INSERT INTO guilds (`leader`, `name`, `signature`) VALUES (?, ?, ?)");
|
try (PreparedStatement ps = con.prepareStatement("INSERT INTO guilds (`leader`, `name`, `signature`) VALUES (?, ?, ?)")) {
|
||||||
ps.setInt(1, leaderId);
|
ps.setInt(1, leaderId);
|
||||||
ps.setString(2, name);
|
ps.setString(2, name);
|
||||||
ps.setInt(3, (int) System.currentTimeMillis());
|
ps.setInt(3, (int) System.currentTimeMillis());
|
||||||
ps.execute();
|
ps.executeUpdate();
|
||||||
ps.close();
|
}
|
||||||
|
|
||||||
ps = con.prepareStatement("SELECT guildid FROM guilds WHERE leader = ?");
|
final int guildId;
|
||||||
ps.setInt(1, leaderId);
|
try (PreparedStatement ps = con.prepareStatement("SELECT guildid FROM guilds WHERE leader = ?")) {
|
||||||
rs = ps.executeQuery();
|
ps.setInt(1, leaderId);
|
||||||
rs.next();
|
|
||||||
int guildId = rs.getInt("guildid");
|
|
||||||
rs.close();
|
|
||||||
ps.close();
|
|
||||||
|
|
||||||
ps = con.prepareStatement("UPDATE characters SET guildid = ? WHERE id = ?");
|
try (ResultSet rs = ps.executeQuery()) {
|
||||||
ps.setInt(1, guildId);
|
rs.next();
|
||||||
ps.setInt(2, leaderId);
|
guildId = rs.getInt("guildid");
|
||||||
ps.executeUpdate();
|
}
|
||||||
ps.close();
|
}
|
||||||
|
|
||||||
|
try (PreparedStatement ps = con.prepareStatement("UPDATE characters SET guildid = ? WHERE id = ?")) {
|
||||||
|
ps.setInt(1, guildId);
|
||||||
|
ps.setInt(2, leaderId);
|
||||||
|
ps.executeUpdate();
|
||||||
|
}
|
||||||
|
|
||||||
con.close();
|
|
||||||
return guildId;
|
return guildId;
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
@@ -646,7 +639,7 @@ public class MapleGuild {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void disbandGuild() {
|
public void disbandGuild() {
|
||||||
if(allianceId > 0) {
|
if (allianceId > 0) {
|
||||||
if (!MapleAlliance.removeGuildFromAlliance(allianceId, id, world)) {
|
if (!MapleAlliance.removeGuildFromAlliance(allianceId, id, world)) {
|
||||||
MapleAlliance.disbandAlliance(allianceId);
|
MapleAlliance.disbandAlliance(allianceId);
|
||||||
}
|
}
|
||||||
@@ -714,7 +707,7 @@ public class MapleGuild {
|
|||||||
this.guildMessage(MaplePacketCreator.getGPMessage(amount));
|
this.guildMessage(MaplePacketCreator.getGPMessage(amount));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void removeGP(int amount){
|
public void removeGP(int amount) {
|
||||||
this.gp -= amount;
|
this.gp -= amount;
|
||||||
this.writeToDB(false);
|
this.writeToDB(false);
|
||||||
this.guildMessage(MaplePacketCreator.updateGP(this.id, this.gp));
|
this.guildMessage(MaplePacketCreator.updateGP(this.id, this.gp));
|
||||||
@@ -776,16 +769,10 @@ public class MapleGuild {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static void displayGuildRanks(MapleClient c, int npcid) {
|
public static void displayGuildRanks(MapleClient c, int npcid) {
|
||||||
try {
|
try (Connection con = DatabaseConnection.getConnection();
|
||||||
ResultSet rs;
|
PreparedStatement ps = con.prepareStatement("SELECT `name`, `GP`, `logoBG`, `logoBGColor`, `logo`, `logoColor` FROM guilds ORDER BY `GP` DESC LIMIT 50", ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
|
||||||
Connection con = DatabaseConnection.getConnection();
|
ResultSet rs = ps.executeQuery()) {
|
||||||
try (PreparedStatement ps = con.prepareStatement("SELECT `name`, `GP`, `logoBG`, `logoBGColor`, `logo`, `logoColor` FROM guilds ORDER BY `GP` DESC LIMIT 50",
|
c.announce(MaplePacketCreator.showGuildRanks(npcid, rs));
|
||||||
ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY)) {
|
|
||||||
rs = ps.executeQuery();
|
|
||||||
c.announce(MaplePacketCreator.showGuildRanks(npcid, rs));
|
|
||||||
}
|
|
||||||
rs.close();
|
|
||||||
con.close();
|
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
System.out.println("failed to display guild ranks. " + e);
|
System.out.println("failed to display guild ranks. " + e);
|
||||||
@@ -798,15 +785,11 @@ public class MapleGuild {
|
|||||||
|
|
||||||
public void setAllianceId(int aid) {
|
public void setAllianceId(int aid) {
|
||||||
this.allianceId = aid;
|
this.allianceId = aid;
|
||||||
try {
|
try (Connection con = DatabaseConnection.getConnection();
|
||||||
Connection con = DatabaseConnection.getConnection();
|
PreparedStatement ps = con.prepareStatement("UPDATE guilds SET allianceId = ? WHERE guildid = ?")) {
|
||||||
try (PreparedStatement ps = con.prepareStatement("UPDATE guilds SET allianceId = ? WHERE guildid = ?")) {
|
ps.setInt(1, aid);
|
||||||
ps.setInt(1, aid);
|
ps.setInt(2, id);
|
||||||
ps.setInt(2, id);
|
ps.executeUpdate();
|
||||||
ps.executeUpdate();
|
|
||||||
}
|
|
||||||
|
|
||||||
con.close();
|
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
@@ -816,8 +799,8 @@ public class MapleGuild {
|
|||||||
try {
|
try {
|
||||||
membersLock.lock();
|
membersLock.lock();
|
||||||
try {
|
try {
|
||||||
for(MapleGuildCharacter mgc: members) {
|
for (MapleGuildCharacter mgc : members) {
|
||||||
if(mgc.isOnline()) {
|
if (mgc.isOnline()) {
|
||||||
mgc.setAllianceRank(5);
|
mgc.setAllianceRank(5);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -825,14 +808,12 @@ public class MapleGuild {
|
|||||||
membersLock.unlock();
|
membersLock.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
Connection con = DatabaseConnection.getConnection();
|
try (Connection con = DatabaseConnection.getConnection();
|
||||||
try (PreparedStatement ps = con.prepareStatement("UPDATE characters SET allianceRank = ? WHERE guildid = ?")) {
|
PreparedStatement ps = con.prepareStatement("UPDATE characters SET allianceRank = ? WHERE guildid = ?")) {
|
||||||
ps.setInt(1, 5);
|
ps.setInt(1, 5);
|
||||||
ps.setInt(2, id);
|
ps.setInt(2, id);
|
||||||
ps.executeUpdate();
|
ps.executeUpdate();
|
||||||
}
|
}
|
||||||
|
|
||||||
con.close();
|
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user