AccessLevels.java 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. /*
  2. * This program is free software: you can redistribute it and/or modify it under
  3. * the terms of the GNU General Public License as published by the Free Software
  4. * Foundation, either version 3 of the License, or (at your option) any later
  5. * version.
  6. *
  7. * This program is distributed in the hope that it will be useful, but WITHOUT
  8. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
  9. * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
  10. * details.
  11. *
  12. * You should have received a copy of the GNU General Public License along with
  13. * this program. If not, see <http://www.gnu.org/licenses/>.
  14. */
  15. package com.l2jserver.gameserver.datatables;
  16. import gnu.trove.TIntObjectHashMap;
  17. import java.sql.Connection;
  18. import java.sql.PreparedStatement;
  19. import java.sql.ResultSet;
  20. import java.sql.SQLException;
  21. import java.util.logging.Level;
  22. import java.util.logging.Logger;
  23. import com.l2jserver.Config;
  24. import com.l2jserver.L2DatabaseFactory;
  25. import com.l2jserver.gameserver.model.L2AccessLevel;
  26. /**
  27. * @author FBIagent<br>
  28. */
  29. public class AccessLevels
  30. {
  31. /** The logger<br> */
  32. private static Logger _log = Logger.getLogger(AccessLevels.class.getName());
  33. /** Reserved master access level<br> */
  34. public static final int _masterAccessLevelNum = Config.MASTERACCESS_LEVEL;
  35. /** The master access level which can use everything<br> */
  36. public static L2AccessLevel _masterAccessLevel = new L2AccessLevel(_masterAccessLevelNum, "Master Access", Config.MASTERACCESS_NAME_COLOR, Config.MASTERACCESS_TITLE_COLOR, null, true, true, true, true, true, true, true, true);
  37. /** Reserved user access level<br> */
  38. public static final int _userAccessLevelNum = 0;
  39. /** The user access level which can do no administrative tasks<br> */
  40. public static L2AccessLevel _userAccessLevel = new L2AccessLevel(_userAccessLevelNum, "User", -1, -1, null, false, false, false, true, false, true, true, true);
  41. /** FastMap of access levels defined in database<br> */
  42. private TIntObjectHashMap<L2AccessLevel> _accessLevels;
  43. /**
  44. * Returns the one and only instance of this class<br><br>
  45. *
  46. * @return AccessLevels: the one and only instance of this class<br>
  47. */
  48. public static AccessLevels getInstance()
  49. {
  50. return SingletonHolder._instance;
  51. }
  52. private AccessLevels()
  53. {
  54. loadAccessLevels();
  55. _accessLevels.put(_userAccessLevelNum, _userAccessLevel);
  56. }
  57. /**
  58. * Loads the access levels from database<br>
  59. */
  60. private void loadAccessLevels()
  61. {
  62. _accessLevels = new TIntObjectHashMap<L2AccessLevel>();
  63. Connection con = null;
  64. try
  65. {
  66. con = L2DatabaseFactory.getInstance().getConnection();
  67. PreparedStatement stmt = con.prepareStatement("SELECT * FROM `access_levels` ORDER BY `accessLevel` DESC");
  68. ResultSet rset = stmt.executeQuery();
  69. int accessLevel = 0;
  70. String name = null;
  71. int nameColor = 0;
  72. int titleColor = 0;
  73. String childs = null;
  74. boolean isGm = false;
  75. boolean allowPeaceAttack = false;
  76. boolean allowFixedRes = false;
  77. boolean allowTransaction = false;
  78. boolean allowAltG = false;
  79. boolean giveDamage = false;
  80. boolean takeAggro = false;
  81. boolean gainExp = false;
  82. while (rset.next())
  83. {
  84. accessLevel = rset.getInt("accessLevel");
  85. name = rset.getString("name");
  86. if (accessLevel == _userAccessLevelNum)
  87. {
  88. _log.warning("AccessLevels: Access level with name " + name + " is using reserved user access level " + _userAccessLevelNum + ". Ignoring it!");
  89. continue;
  90. }
  91. else if (accessLevel == _masterAccessLevelNum)
  92. {
  93. _log.warning("AccessLevels: Access level with name " + name + " is using reserved master access level " + _masterAccessLevelNum + ". Ignoring it!");
  94. continue;
  95. }
  96. else if (accessLevel < 0)
  97. {
  98. _log.warning("AccessLevels: Access level with name " + name + " is using banned access level state(below 0). Ignoring it!");
  99. continue;
  100. }
  101. try
  102. {
  103. nameColor = Integer.decode("0x" + rset.getString("nameColor"));
  104. }
  105. catch (NumberFormatException nfe)
  106. {
  107. try
  108. {
  109. nameColor = Integer.decode("0xFFFFFF");
  110. }
  111. catch (NumberFormatException nfe2)
  112. {
  113. }
  114. }
  115. try
  116. {
  117. titleColor = Integer.decode("0x" + rset.getString("titleColor"));
  118. }
  119. catch (NumberFormatException nfe)
  120. {
  121. try
  122. {
  123. titleColor = Integer.decode("0xFFFF77");
  124. }
  125. catch (NumberFormatException nfe2)
  126. {
  127. }
  128. }
  129. childs = rset.getString("childAccess");
  130. isGm = rset.getBoolean("isGm");
  131. allowPeaceAttack = rset.getBoolean("allowPeaceAttack");
  132. allowFixedRes = rset.getBoolean("allowFixedRes");
  133. allowTransaction = rset.getBoolean("allowTransaction");
  134. allowAltG = rset.getBoolean("allowAltg");
  135. giveDamage = rset.getBoolean("giveDamage");
  136. takeAggro = rset.getBoolean("takeAggro");
  137. gainExp = rset.getBoolean("gainExp");
  138. _accessLevels.put(accessLevel, new L2AccessLevel(accessLevel, name, nameColor, titleColor, childs.isEmpty() ? null : childs, isGm, allowPeaceAttack, allowFixedRes, allowTransaction, allowAltG, giveDamage, takeAggro, gainExp));
  139. }
  140. rset.close();
  141. stmt.close();
  142. }
  143. catch (SQLException e)
  144. {
  145. _log.log(Level.WARNING, "AccessLevels: Error loading from database:" + e.getMessage(), e);
  146. }
  147. finally
  148. {
  149. L2DatabaseFactory.close(con);
  150. }
  151. _log.info("AccessLevels: Loaded " + _accessLevels.size() + " from database.");
  152. }
  153. /**
  154. * Returns the access level by characterAccessLevel<br><br>
  155. *
  156. * @param accessLevelNum as int<br><br>
  157. *
  158. * @return AccessLevel: AccessLevel instance by char access level<br>
  159. */
  160. public L2AccessLevel getAccessLevel(int accessLevelNum)
  161. {
  162. L2AccessLevel accessLevel = null;
  163. synchronized (_accessLevels)
  164. {
  165. accessLevel = _accessLevels.get(accessLevelNum);
  166. }
  167. return accessLevel;
  168. }
  169. public void addBanAccessLevel(int accessLevel)
  170. {
  171. synchronized (_accessLevels)
  172. {
  173. if (accessLevel > -1)
  174. {
  175. return;
  176. }
  177. _accessLevels.put(accessLevel, new L2AccessLevel(accessLevel, "Banned", -1, -1, null, false, false, false, false, false, false, false, false));
  178. }
  179. }
  180. public void reloadAccessLevels()
  181. {
  182. loadAccessLevels();
  183. }
  184. @SuppressWarnings("synthetic-access")
  185. private static class SingletonHolder
  186. {
  187. protected static final AccessLevels _instance = new AccessLevels();
  188. }
  189. }