CharSelectionInfo.java 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394
  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.network.serverpackets;
  16. import java.sql.Connection;
  17. import java.sql.PreparedStatement;
  18. import java.sql.ResultSet;
  19. import java.util.List;
  20. import java.util.logging.Level;
  21. import java.util.logging.Logger;
  22. import com.l2jserver.L2DatabaseFactory;
  23. import com.l2jserver.gameserver.datatables.ClanTable;
  24. import com.l2jserver.gameserver.instancemanager.CursedWeaponsManager;
  25. import com.l2jserver.gameserver.model.CharSelectInfoPackage;
  26. import com.l2jserver.gameserver.model.L2Clan;
  27. import com.l2jserver.gameserver.model.itemcontainer.Inventory;
  28. import com.l2jserver.gameserver.network.L2GameClient;
  29. import javolution.util.FastList;
  30. /**
  31. * This class ...
  32. *
  33. * @version $Revision: 1.8.2.4.2.6 $ $Date: 2005/04/06 16:13:46 $
  34. */
  35. public class CharSelectionInfo extends L2GameServerPacket
  36. {
  37. // d SdSddddddddddffddddddddddddddddddddddddddddddddddddddddddddddffd
  38. private static final String _S__1F_CHARSELECTINFO = "[S] 09 CharSelectInfo";
  39. private static Logger _log = Logger.getLogger(CharSelectionInfo.class.getName());
  40. private String _loginName;
  41. private int _sessionId, _activeId;
  42. private CharSelectInfoPackage[] _characterPackages;
  43. /**
  44. * @param _characters
  45. */
  46. public CharSelectionInfo(String loginName, int sessionId)
  47. {
  48. _sessionId = sessionId;
  49. _loginName = loginName;
  50. _characterPackages = loadCharacterSelectInfo();
  51. _activeId = -1;
  52. }
  53. public CharSelectionInfo(String loginName, int sessionId, int activeId)
  54. {
  55. _sessionId = sessionId;
  56. _loginName = loginName;
  57. _characterPackages = loadCharacterSelectInfo();
  58. _activeId = activeId;
  59. }
  60. public CharSelectInfoPackage[] getCharInfo()
  61. {
  62. return _characterPackages;
  63. }
  64. @Override
  65. protected final void writeImpl()
  66. {
  67. writeC(0x09);
  68. int size = (_characterPackages.length);
  69. writeD(size);
  70. // Can prevent players from creating new characters (if 0); (if 1, the client will ask if chars may be created (0x13) Response: (0x0D) )
  71. writeD(0x07);
  72. writeC(0x00);
  73. long lastAccess = 0L;
  74. if (_activeId == -1)
  75. {
  76. for (int i = 0; i < size; i++)
  77. {
  78. if (lastAccess < _characterPackages[i].getLastAccess())
  79. {
  80. lastAccess = _characterPackages[i].getLastAccess();
  81. _activeId = i;
  82. }
  83. }
  84. }
  85. for (int i = 0; i < size; i++)
  86. {
  87. CharSelectInfoPackage charInfoPackage = _characterPackages[i];
  88. writeS(charInfoPackage.getName());
  89. writeD(charInfoPackage.getCharId());
  90. writeS(_loginName);
  91. writeD(_sessionId);
  92. writeD(charInfoPackage.getClanId());
  93. writeD(0x00); // ??
  94. writeD(charInfoPackage.getSex());
  95. writeD(charInfoPackage.getRace());
  96. if (charInfoPackage.getClassId() == charInfoPackage.getBaseClassId())
  97. writeD(charInfoPackage.getClassId());
  98. else
  99. writeD(charInfoPackage.getBaseClassId());
  100. writeD(0x01); // active ??
  101. writeD(charInfoPackage.getX()); // x
  102. writeD(charInfoPackage.getY()); // y
  103. writeD(charInfoPackage.getZ()); // z
  104. writeF(charInfoPackage.getCurrentHp()); // hp cur
  105. writeF(charInfoPackage.getCurrentMp()); // mp cur
  106. writeD(charInfoPackage.getSp());
  107. writeQ(charInfoPackage.getExp());
  108. writeD(charInfoPackage.getLevel());
  109. writeD(charInfoPackage.getKarma()); // karma
  110. writeD(charInfoPackage.getPkKills());
  111. writeD(charInfoPackage.getPvPKills());
  112. writeD(0x00);
  113. writeD(0x00);
  114. writeD(0x00);
  115. writeD(0x00);
  116. writeD(0x00);
  117. writeD(0x00);
  118. writeD(0x00);
  119. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_HAIRALL));
  120. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_REAR));
  121. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_LEAR));
  122. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_NECK));
  123. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_RFINGER));
  124. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_LFINGER));
  125. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_HEAD));
  126. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_RHAND));
  127. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_LHAND));
  128. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_GLOVES));
  129. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_CHEST));
  130. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_LEGS));
  131. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_FEET));
  132. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_BACK));
  133. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_LRHAND));
  134. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_HAIR));
  135. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_HAIR2));
  136. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_RBRACELET));
  137. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_LBRACELET));
  138. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_DECO1));
  139. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_DECO2));
  140. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_DECO3));
  141. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_DECO4));
  142. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_DECO5));
  143. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_DECO6));
  144. writeD(charInfoPackage.getPaperdollItemId(Inventory.PAPERDOLL_BELT));
  145. writeD(charInfoPackage.getHairStyle());
  146. writeD(charInfoPackage.getHairColor());
  147. writeD(charInfoPackage.getFace());
  148. writeF(charInfoPackage.getMaxHp()); // hp max
  149. writeF(charInfoPackage.getMaxMp()); // mp max
  150. long deleteTime = charInfoPackage.getDeleteTimer();
  151. int deletedays = 0;
  152. if (deleteTime > 0)
  153. deletedays = (int)((deleteTime-System.currentTimeMillis())/1000);
  154. writeD(deletedays); // days left before
  155. // delete .. if != 0
  156. // then char is inactive
  157. writeD(charInfoPackage.getClassId());
  158. if (i == _activeId)
  159. writeD(0x01);
  160. else
  161. writeD(0x00); //c3 auto-select char
  162. writeC(charInfoPackage.getEnchantEffect() > 127 ? 127 : charInfoPackage.getEnchantEffect());
  163. writeD(charInfoPackage.getAugmentationId());
  164. //writeD(charInfoPackage.getTransformId()); // Used to display Transformations
  165. writeD(0x00); // Currently on retail when you are on character select you don't see your transformation.
  166. }
  167. }
  168. private CharSelectInfoPackage[] loadCharacterSelectInfo()
  169. {
  170. CharSelectInfoPackage charInfopackage;
  171. List<CharSelectInfoPackage> characterList = new FastList<CharSelectInfoPackage>();
  172. Connection con = null;
  173. try
  174. {
  175. con = L2DatabaseFactory.getInstance().getConnection();
  176. PreparedStatement statement = con.prepareStatement("SELECT account_name, charId, char_name, level, maxHp, curHp, maxMp, curMp, face, hairStyle, hairColor, sex, heading, x, y, z, exp, sp, karma, pvpkills, pkkills, clanid, race, classid, deletetime, cancraft, title, rec_have, rec_left, accesslevel, online, char_slot, lastAccess, base_class, transform_id FROM characters WHERE account_name=?");
  177. statement.setString(1, _loginName);
  178. ResultSet charList = statement.executeQuery();
  179. while (charList.next())// fills the package
  180. {
  181. charInfopackage = restoreChar(charList);
  182. if ( charInfopackage != null )
  183. characterList.add(charInfopackage);
  184. }
  185. charList.close();
  186. statement.close();
  187. return characterList.toArray(new CharSelectInfoPackage[characterList.size()]);
  188. }
  189. catch (Exception e)
  190. {
  191. _log.log(Level.WARNING, "Could not restore char info: " + e.getMessage(), e);
  192. }
  193. finally
  194. {
  195. L2DatabaseFactory.close(con);
  196. }
  197. return new CharSelectInfoPackage[0];
  198. }
  199. private void loadCharacterSubclassInfo(CharSelectInfoPackage charInfopackage, int ObjectId, int activeClassId)
  200. {
  201. Connection con = null;
  202. try
  203. {
  204. con = L2DatabaseFactory.getInstance().getConnection();
  205. PreparedStatement statement = con.prepareStatement("SELECT exp, sp, level FROM character_subclasses WHERE charId=? && class_id=? ORDER BY charId");
  206. statement.setInt(1, ObjectId);
  207. statement.setInt(2, activeClassId);
  208. ResultSet charList = statement.executeQuery();
  209. if (charList.next())
  210. {
  211. charInfopackage.setExp(charList.getLong("exp"));
  212. charInfopackage.setSp(charList.getInt("sp"));
  213. charInfopackage.setLevel(charList.getInt("level"));
  214. }
  215. charList.close();
  216. statement.close();
  217. }
  218. catch (Exception e)
  219. {
  220. _log.log(Level.WARNING, "Could not restore char subclass info: " + e.getMessage(), e);
  221. }
  222. finally
  223. {
  224. try { L2DatabaseFactory.close(con); } catch (Exception e) {}
  225. }
  226. }
  227. private CharSelectInfoPackage restoreChar(ResultSet chardata) throws Exception
  228. {
  229. int objectId = chardata.getInt("charId");
  230. String name = chardata.getString("char_name");
  231. // See if the char must be deleted
  232. long deletetime = chardata.getLong("deletetime");
  233. if (deletetime > 0)
  234. {
  235. if (System.currentTimeMillis() > deletetime)
  236. {
  237. L2Clan clan = ClanTable.getInstance().getClan(chardata.getInt("clanid"));
  238. if(clan != null)
  239. clan.removeClanMember(objectId, 0);
  240. L2GameClient.deleteCharByObjId(objectId);
  241. return null;
  242. }
  243. }
  244. CharSelectInfoPackage charInfopackage = new CharSelectInfoPackage(objectId, name);
  245. charInfopackage.setLevel(chardata.getInt("level"));
  246. charInfopackage.setMaxHp(chardata.getInt("maxhp"));
  247. charInfopackage.setCurrentHp(chardata.getDouble("curhp"));
  248. charInfopackage.setMaxMp(chardata.getInt("maxmp"));
  249. charInfopackage.setCurrentMp(chardata.getDouble("curmp"));
  250. charInfopackage.setKarma(chardata.getInt("karma"));
  251. charInfopackage.setPkKills(chardata.getInt("pkkills"));
  252. charInfopackage.setPvPKills(chardata.getInt("pvpkills"));
  253. charInfopackage.setFace(chardata.getInt("face"));
  254. charInfopackage.setHairStyle(chardata.getInt("hairstyle"));
  255. charInfopackage.setHairColor(chardata.getInt("haircolor"));
  256. charInfopackage.setSex(chardata.getInt("sex"));
  257. charInfopackage.setExp(chardata.getLong("exp"));
  258. charInfopackage.setSp(chardata.getInt("sp"));
  259. charInfopackage.setClanId(chardata.getInt("clanid"));
  260. charInfopackage.setRace(chardata.getInt("race"));
  261. final int baseClassId = chardata.getInt("base_class");
  262. final int activeClassId = chardata.getInt("classid");
  263. charInfopackage.setX(chardata.getInt("x"));
  264. charInfopackage.setY(chardata.getInt("y"));
  265. charInfopackage.setZ(chardata.getInt("z"));
  266. // if is in subclass, load subclass exp, sp, lvl info
  267. if(baseClassId != activeClassId)
  268. loadCharacterSubclassInfo(charInfopackage, objectId, activeClassId);
  269. charInfopackage.setClassId(activeClassId);
  270. // Get the augmentation id for equipped weapon
  271. int weaponObjId = charInfopackage.getPaperdollObjectId(Inventory.PAPERDOLL_LRHAND);
  272. if (weaponObjId < 1)
  273. weaponObjId = charInfopackage.getPaperdollObjectId(Inventory.PAPERDOLL_RHAND);
  274. // Check Transformation
  275. int cursedWeaponId = CursedWeaponsManager.getInstance().checkOwnsWeaponId(objectId);
  276. if (cursedWeaponId > 0)
  277. {
  278. // cursed weapon transformations
  279. if(cursedWeaponId == 8190)
  280. charInfopackage.setTransformId(301);
  281. else if(cursedWeaponId == 8689)
  282. charInfopackage.setTransformId(302);
  283. else
  284. charInfopackage.setTransformId(0);
  285. }
  286. else if (chardata.getInt("transform_id") > 0)
  287. {
  288. charInfopackage.setTransformId(chardata.getInt("transform_id"));
  289. }
  290. else
  291. charInfopackage.setTransformId(0);
  292. if (weaponObjId > 0)
  293. {
  294. Connection con = null;
  295. try
  296. {
  297. con = L2DatabaseFactory.getInstance().getConnection();
  298. PreparedStatement statement = con.prepareStatement("SELECT augAttributes FROM item_attributes WHERE itemId=?");
  299. statement.setInt(1, weaponObjId);
  300. ResultSet result = statement.executeQuery();
  301. if (result.next())
  302. {
  303. int augment = result.getInt("augAttributes");
  304. charInfopackage.setAugmentationId(augment == -1 ? 0 : augment);
  305. }
  306. result.close();
  307. statement.close();
  308. }
  309. catch (Exception e)
  310. {
  311. _log.log(Level.WARNING, "Could not restore augmentation info: " + e.getMessage(), e);
  312. }
  313. finally { try { L2DatabaseFactory.close(con); } catch (Exception e) {} }
  314. }
  315. /*
  316. * Check if the base class is set to zero and alse doesn't match
  317. * with the current active class, otherwise send the base class ID.
  318. *
  319. * This prevents chars created before base class was introduced
  320. * from being displayed incorrectly.
  321. */
  322. if (baseClassId == 0 && activeClassId > 0)
  323. charInfopackage.setBaseClassId(activeClassId);
  324. else
  325. charInfopackage.setBaseClassId(baseClassId);
  326. charInfopackage.setDeleteTimer(deletetime);
  327. charInfopackage.setLastAccess(chardata.getLong("lastAccess"));
  328. return charInfopackage;
  329. }
  330. @Override
  331. public String getType()
  332. {
  333. return _S__1F_CHARSELECTINFO;
  334. }
  335. }