/*
* 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 <http://www.gnu.org/licenses/>.
*/
package com.l2jfrozen.gameserver.datatables.sql;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.logging.Logger;
import javolution.util.FastMap;
import com.l2jfrozen.Config;
import com.l2jfrozen.gameserver.datatables.AccessLevel;
import com.l2jfrozen.util.CloseUtil;
import com.l2jfrozen.util.database.L2DatabaseFactory;
/**
* @author FBIagent<br>
*/
public class AccessLevels
{
private static final Logger _log = Logger.getLogger(AccessLevels.class.getName());
/** The one and only instance of this class, retriveable by getInstance()<br> */
private static AccessLevels _instance = null;
/** Reserved master access level<br> */
//public static final int _masterAccessLevelNum = Config.MASTERACCESS_LEVEL;
/** The master access level which can use everything<br> */
//L2EMU_EDIT - Rayan -
public AccessLevel _masterAccessLevel;/* = new AccessLevel(_masterAccessLevelNum, "Master Access", Config.MASTERACCESS_NAME_COLOR, Config.MASTERACCESS_TITLE_COLOR, true, true, true, true, true, true, true, true, true, true, true);
//L2EMU_EDIT
/** Reserved user access level<br> */
//public static final int _userAccessLevelNum = 0;
/** The user access level which can do no administrative tasks<br> */
//L2EMU_EDIT - Rayan -
public AccessLevel _userAccessLevel;/* = new AccessLevel(_userAccessLevelNum, "User", Integer.decode("0xFFFFFF"), Integer.decode("0xFFFFFF"), false, false, false, true, false, true, true, true, true, true, false);
//L2EMU_EDIT
/** FastMap of access levels defined in database<br> */
private final FastMap<Integer, AccessLevel> _accessLevels = new FastMap<Integer, AccessLevel>();
/**
* Loads the access levels from database<br>
*/
private AccessLevels()
{
_masterAccessLevel = new AccessLevel(Config.MASTERACCESS_LEVEL, "Master Access", Config.MASTERACCESS_NAME_COLOR, Config.MASTERACCESS_TITLE_COLOR, true, true, true, true, true, true, true, true, true, true, true);
_userAccessLevel = new AccessLevel(Config.USERACCESS_LEVEL, "User", Integer.decode("0xFFFFFF"), Integer.decode("0xFFFFFF"), false, false, false, true, false, true, true, true, true, true, false);
Connection con = null;
try
{
con = L2DatabaseFactory.getInstance().getConnection(false);
final PreparedStatement stmt = con.prepareStatement("SELECT * FROM `access_levels` ORDER BY `accessLevel` DESC");
final ResultSet rset = stmt.executeQuery();
int accessLevel = 0;
String name = null;
int nameColor = 0;
int titleColor = 0;
boolean isGm = false;
boolean allowPeaceAttack = false;
boolean allowFixedRes = false;
boolean allowTransaction = false;
boolean allowAltG = false;
boolean giveDamage = false;
boolean takeAggro = false;
boolean gainExp = false;
//L2EMU_ADD
boolean useNameColor = true;
boolean useTitleColor = false;
boolean canDisableGmStatus = true;
//L2EMU_ADD
while(rset.next())
{
accessLevel = rset.getInt("accessLevel");
name = rset.getString("name");
if(accessLevel == Config.USERACCESS_LEVEL) {
_log.finest("AccessLevels: Access level with name {} is using reserved user access level {}. Ignoring it.. "+ name+" "+ Config.USERACCESS_LEVEL);
continue;
}
else if(accessLevel == Config.MASTERACCESS_LEVEL)
{
_log.finest("AccessLevels: Access level with name {} is using reserved master access level {}. Ignoring it.. "+ name+" "+ Config.MASTERACCESS_LEVEL );
continue;
}
else if(accessLevel < 0)
{
_log.finest("AccessLevels: Access level with name {} is using banned access level state(below 0). Ignoring it.. "+ name);
continue;
}
try
{
nameColor = Integer.decode("0x" + rset.getString("nameColor"));
}
catch(NumberFormatException nfe)
{
_log.finest(nfe.getMessage()+" "+ nfe);
try
{
nameColor = Integer.decode("0xFFFFFF");
}
catch(NumberFormatException nfe2)
{
_log.finest(nfe.getMessage() + nfe);
}
}
try
{
titleColor = Integer.decode("0x" + rset.getString("titleColor"));
}
catch(NumberFormatException nfe)
{
_log.finest(nfe.getMessage()+" "+ nfe);
try
{
titleColor = Integer.decode("0x77FFFF");
}
catch(NumberFormatException nfe2)
{
_log.finest(nfe.getMessage()+" "+ nfe);
}
}
isGm = rset.getBoolean("isGm");
allowPeaceAttack = rset.getBoolean("allowPeaceAttack");
allowFixedRes = rset.getBoolean("allowFixedRes");
allowTransaction = rset.getBoolean("allowTransaction");
allowAltG = rset.getBoolean("allowAltg");
giveDamage = rset.getBoolean("giveDamage");
takeAggro = rset.getBoolean("takeAggro");
gainExp = rset.getBoolean("gainExp");
//L2EMU_ADD - Rayan for temp access
useNameColor = rset.getBoolean("useNameColor");
useTitleColor = rset.getBoolean("useTitleColor");
canDisableGmStatus = rset.getBoolean("canDisableGmStatus");
//L2EMU_EDIT - Rayan for temp access
_accessLevels.put(accessLevel, new AccessLevel(accessLevel, name, nameColor, titleColor, isGm, allowPeaceAttack, allowFixedRes, allowTransaction, allowAltG, giveDamage, takeAggro, gainExp, useNameColor, useTitleColor, canDisableGmStatus));
//L2EMU_EDIT
}
rset.close();
stmt.close();
}
catch(SQLException e)
{
_log.severe("AccessLevels: Error loading from database "+ e);
}
finally
{
CloseUtil.close(con);
}
//_log.info("AccessLevels: Loaded " + _accessLevels.size() + " Access Levels from database.");
_log.finest("AccessLevels: Master Access Level is " + Config.MASTERACCESS_LEVEL);
_log.finest("AccessLevels: User Access Level is " + Config.USERACCESS_LEVEL);
if(Config.DEBUG) for(int actual : _accessLevels.keySet()){
AccessLevel actual_access = _accessLevels.get(actual);
_log.finest("AccessLevels: {} Access Level is {} "+ actual_access.getName()+" "+ actual_access.getLevel());
}
}
/**
* Returns the one and only instance of this class<br>
* <br>
*
* @return AccessLevels: the one and only instance of this class<br>
*/
public static AccessLevels getInstance()
{
return _instance == null ? (_instance = new AccessLevels()) : _instance;
}
/**
* Returns the access level by characterAccessLevel<br>
* <br>
*
* @param accessLevelNum as int<br>
* <br>
* @return AccessLevel: AccessLevel instance by char access level<br>
*/
public AccessLevel getAccessLevel(int accessLevelNum)
{
AccessLevel accessLevel = null;
synchronized (_accessLevels)
{
accessLevel = _accessLevels.get(accessLevelNum);
}
return accessLevel;
}
public void addBanAccessLevel(int accessLevel)
{
synchronized (_accessLevels)
{
if(accessLevel > -1)
return;
//L2EMU_ADD - Rayan -
_accessLevels.put(accessLevel, new AccessLevel(accessLevel, "Banned", Integer.decode("0x000000"), Integer.decode("0x000000"), false, false, false, false, false, false, false, false, false, false, false));
//L2EMU_ADD
}
}
public static void reload(){
_instance = null;
getInstance();
}
}