CharSelectionInfo.java 16 KB

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