/* * This program 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. * * This program 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 * this program. If not, see . */ package com.l2jserver.gameserver.instancemanager; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.Map; import java.util.Map.Entry; import java.util.logging.Level; import java.util.logging.Logger; import com.l2jserver.L2DatabaseFactory; import com.l2jserver.gameserver.model.actor.instance.L2PcInstance; import javolution.util.FastList; import javolution.util.FastMap; /** * @author Kerberos */ public class RaidBossPointsManager { private final static Logger _log = Logger.getLogger(RaidBossPointsManager.class.getName()); protected static FastMap> _list; private static final Comparator> _comparator = new Comparator>(){ public int compare(Map.Entry entry, Map.Entry entry1) { return entry.getValue().equals(entry1.getValue()) ? 0 : entry.getValue() < entry1.getValue() ? 1 : -1; } }; public final static void init() { _list = new FastMap>(); FastList _chars = new FastList(); Connection con = null; try { con = L2DatabaseFactory.getInstance().getConnection(); PreparedStatement statement = con.prepareStatement("SELECT * FROM `character_raid_points`"); ResultSet rset = statement.executeQuery(); while(rset.next()) { _chars.add(rset.getInt("charId")); } rset.close(); statement.close(); statement = con.prepareStatement("SELECT * FROM `character_raid_points` WHERE `charId`=?"); for(FastList.Node n = _chars.head(), end = _chars.tail(); (n = n.getNext()) != end;) { int charId = n.getValue(); FastMap values = new FastMap(); statement.setInt(1, charId); rset = statement.executeQuery(); statement.clearParameters(); while(rset.next()) { values.put(rset.getInt("boss_id"), rset.getInt("points")); } rset.close(); _list.put(charId, values); } statement.close(); } catch (SQLException e) { _log.warning("RaidPointsManager: Couldnt load raid points "); } catch (Exception e) { _log.warning(e.getMessage()); } finally { L2DatabaseFactory.close(con); } } public final static void updatePointsInDB(L2PcInstance player, int raidId, int points) { Connection con = null; try { con = L2DatabaseFactory.getInstance().getConnection(); PreparedStatement statement; statement = con.prepareStatement("REPLACE INTO character_raid_points (`charId`,`boss_id`,`points`) VALUES (?,?,?)"); statement.setInt(1, player.getObjectId()); statement.setInt(2, raidId); statement.setInt(3, points); statement.executeUpdate(); statement.close(); } catch (Exception e) { _log.log(Level.WARNING, "could not update char raid points:", e); } finally { L2DatabaseFactory.close(con); } } public final static void addPoints(L2PcInstance player, int bossId, int points) { int ownerId = player.getObjectId(); Map tmpPoint; if (_list == null) _list = new FastMap>(); tmpPoint = _list.get(ownerId); if(tmpPoint == null || tmpPoint.isEmpty()) { tmpPoint = new FastMap(); tmpPoint.put(bossId, points); updatePointsInDB(player, bossId, points); } else { int currentPoins = tmpPoint.containsKey(bossId) ? tmpPoint.get(bossId).intValue() : 0; tmpPoint.remove(bossId); tmpPoint.put(bossId, currentPoins == 0 ? points : currentPoins + points); updatePointsInDB(player, bossId, currentPoins == 0 ? points : currentPoins + points); } _list.remove(ownerId); _list.put(ownerId, tmpPoint); } public final static int getPointsByOwnerId(int ownerId) { Map tmpPoint; if (_list == null) _list = new FastMap>(); tmpPoint = _list.get(ownerId); int totalPoints = 0; if (tmpPoint == null || tmpPoint.isEmpty()) return 0; for(int bossId : tmpPoint.keySet()) { totalPoints += tmpPoint.get(bossId); } return totalPoints; } public final static Map getList(L2PcInstance player) { return _list.get(player.getObjectId()); } public final static void cleanUp() { Connection con = null; try { con = L2DatabaseFactory.getInstance().getConnection(); PreparedStatement statement; statement = con.prepareStatement("DELETE from character_raid_points WHERE charId > 0"); statement.executeUpdate(); statement.close(); _list.clear(); _list = new FastMap>(); } catch (Exception e) { _log.log(Level.WARNING, "could not clean raid points: ", e); } finally { L2DatabaseFactory.close(con); } } public final static int calculateRanking(int playerObjId) { Map tmpRanking = new FastMap(); Map tmpPoints = new FastMap(); int totalPoints; for(int ownerId : _list.keySet()) { totalPoints = getPointsByOwnerId(ownerId); if(totalPoints != 0) { tmpPoints.put(ownerId, totalPoints); } } ArrayList> list = new ArrayList>(tmpPoints.entrySet()); Collections.sort(list, _comparator); int ranking = 1; for(Map.Entry entry : list) tmpRanking.put(entry.getKey(), ranking++); if (tmpRanking.containsKey(playerObjId)) return tmpRanking.get(playerObjId); return 0; } public static Map getRankList() { Map tmpRanking = new FastMap(); Map tmpPoints = new FastMap(); int totalPoints; for(int ownerId : _list.keySet()) { totalPoints = getPointsByOwnerId(ownerId); if(totalPoints != 0) { tmpPoints.put(ownerId, totalPoints); } } ArrayList> list = new ArrayList>(tmpPoints.entrySet()); Collections.sort(list, _comparator); int ranking = 1; for(Map.Entry entry : list) tmpRanking.put(entry.getKey(), ranking++); return tmpRanking; } }