AccessLevels.java 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  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 net.sf.l2j.gameserver.datatables;
  16. import java.sql.PreparedStatement;
  17. import java.sql.ResultSet;
  18. import java.sql.SQLException;
  19. import java.util.Map;
  20. import java.util.logging.Logger;
  21. import javolution.util.FastMap;
  22. import net.sf.l2j.Config;
  23. import net.sf.l2j.L2DatabaseFactory;
  24. import net.sf.l2j.gameserver.model.L2AccessLevel;
  25. /**
  26. * @author FBIagent<br>
  27. */
  28. public class AccessLevels
  29. {
  30. /** The logger<br> */
  31. private static Logger _log = Logger.getLogger(AccessLevels.class.getName());
  32. /** The one and only instance of this class, retrievable by getInstance()<br> */
  33. private static AccessLevels _instance = null;
  34. /** Reserved master access level<br> */
  35. public static final int _masterAccessLevelNum = Config.MASTERACCESS_LEVEL;
  36. /** The master access level which can use everything<br> */
  37. 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);
  38. /** Reserved user access level<br> */
  39. public static final int _userAccessLevelNum = 0;
  40. /** The user access level which can do no administrative tasks<br> */
  41. public static L2AccessLevel _userAccessLevel = new L2AccessLevel(_userAccessLevelNum, "User", Integer.decode("0xFFFFFF"), Integer.decode("0xFFFFFF"), null, false, false, false, true, false, true, true, true);
  42. /** FastMap of access levels defined in database<br> */
  43. private Map<Integer, L2AccessLevel> _accessLevels;
  44. /**
  45. * Returns the one and only instance of this class<br><br>
  46. *
  47. * @return AccessLevels: the one and only instance of this class<br>
  48. */
  49. public static AccessLevels getInstance()
  50. {
  51. if (_instance == null)
  52. _instance = new AccessLevels();
  53. return _instance;
  54. }
  55. private AccessLevels()
  56. {
  57. loadAccessLevels();
  58. }
  59. /**
  60. * Loads the access levels from database<br>
  61. */
  62. private void loadAccessLevels()
  63. {
  64. _accessLevels = new FastMap<Integer, L2AccessLevel>();
  65. java.sql.Connection con = null;
  66. try
  67. {
  68. con = L2DatabaseFactory.getInstance().getConnection();
  69. PreparedStatement stmt = con.prepareStatement("SELECT * FROM `access_levels` ORDER BY `accessLevel` DESC");
  70. ResultSet rset = stmt.executeQuery();
  71. int accessLevel = 0;
  72. String name = null;
  73. int nameColor = 0;
  74. int titleColor = 0;
  75. String childs = null;
  76. boolean isGm = false;
  77. boolean allowPeaceAttack = false;
  78. boolean allowFixedRes = false;
  79. boolean allowTransaction = false;
  80. boolean allowAltG = false;
  81. boolean giveDamage = false;
  82. boolean takeAggro = false;
  83. boolean gainExp = false;
  84. while (rset.next())
  85. {
  86. accessLevel = rset.getInt("accessLevel");
  87. name = rset.getString("name");
  88. if (accessLevel == _userAccessLevelNum)
  89. {
  90. _log.warning("AccessLevels: Access level with name " + name + " is using reserved user access level " + _userAccessLevelNum + ". Ignoring it!");
  91. continue;
  92. }
  93. else if (accessLevel == _masterAccessLevelNum)
  94. {
  95. _log.warning("AccessLevels: Access level with name " + name + " is using reserved master access level " + _masterAccessLevelNum + ". Ignoring it!");
  96. continue;
  97. }
  98. else if (accessLevel < 0)
  99. {
  100. _log.warning("AccessLevels: Access level with name " + name + " is using banned access level state(below 0). Ignoring it!");
  101. continue;
  102. }
  103. try
  104. {
  105. nameColor = Integer.decode("0x" + rset.getString("nameColor"));
  106. }
  107. catch (NumberFormatException nfe)
  108. {
  109. try
  110. {
  111. nameColor = Integer.decode("0xFFFFFF");
  112. }
  113. catch (NumberFormatException nfe2)
  114. {
  115. }
  116. }
  117. try
  118. {
  119. titleColor = Integer.decode("0x" + rset.getString("titleColor"));
  120. }
  121. catch (NumberFormatException nfe)
  122. {
  123. try
  124. {
  125. titleColor = Integer.decode("0x77FFFF");
  126. }
  127. catch (NumberFormatException nfe2)
  128. {
  129. }
  130. }
  131. childs = rset.getString("childAccess");
  132. isGm = rset.getBoolean("isGm");
  133. allowPeaceAttack = rset.getBoolean("allowPeaceAttack");
  134. allowFixedRes = rset.getBoolean("allowFixedRes");
  135. allowTransaction = rset.getBoolean("allowTransaction");
  136. allowAltG = rset.getBoolean("allowAltg");
  137. giveDamage = rset.getBoolean("giveDamage");
  138. takeAggro = rset.getBoolean("takeAggro");
  139. gainExp = rset.getBoolean("gainExp");
  140. _accessLevels.put(accessLevel, new L2AccessLevel(accessLevel, name, nameColor, titleColor, childs.equals("") ? null : childs, isGm, allowPeaceAttack, allowFixedRes, allowTransaction, allowAltG, giveDamage, takeAggro, gainExp));
  141. }
  142. rset.close();
  143. stmt.close();
  144. }
  145. catch (SQLException e)
  146. {
  147. _log.warning("AccessLevels: Error loading from database:" + e);
  148. }
  149. finally
  150. {
  151. try
  152. {
  153. con.close();
  154. }
  155. catch (Exception e)
  156. {
  157. }
  158. }
  159. _log.info("AccessLevels: Loaded " + _accessLevels.size() + " from database.");
  160. }
  161. /**
  162. * Returns the access level by characterAccessLevel<br><br>
  163. *
  164. * @param accessLevelNum as int<br><br>
  165. *
  166. * @return AccessLevel: AccessLevel instance by char access level<br>
  167. */
  168. public L2AccessLevel getAccessLevel(int accessLevelNum)
  169. {
  170. L2AccessLevel accessLevel = null;
  171. synchronized (_accessLevels)
  172. {
  173. accessLevel = _accessLevels.get(accessLevelNum);
  174. }
  175. return accessLevel;
  176. }
  177. public void addBanAccessLevel(int accessLevel)
  178. {
  179. synchronized (_accessLevels)
  180. {
  181. if (accessLevel > -1)
  182. {
  183. return;
  184. }
  185. _accessLevels.put(accessLevel, new L2AccessLevel(accessLevel, "Banned", Integer.decode("0x000000"), Integer.decode("0x000000"), null, false, false, false, false, false, false, false, false));
  186. }
  187. }
  188. public void reloadAccessLevels()
  189. {
  190. loadAccessLevels();
  191. }
  192. }