/*
* 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;
}
}