RequestAquireSkill.java 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485
  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.clientpackets;
  16. import java.util.logging.Logger;
  17. import com.l2jserver.Config;
  18. import com.l2jserver.gameserver.datatables.SkillSpellbookTable;
  19. import com.l2jserver.gameserver.datatables.SkillTable;
  20. import com.l2jserver.gameserver.datatables.SkillTreeTable;
  21. import com.l2jserver.gameserver.model.L2ItemInstance;
  22. import com.l2jserver.gameserver.model.L2PledgeSkillLearn;
  23. import com.l2jserver.gameserver.model.L2ShortCut;
  24. import com.l2jserver.gameserver.model.L2Skill;
  25. import com.l2jserver.gameserver.model.L2SkillLearn;
  26. import com.l2jserver.gameserver.model.L2TransformSkillLearn;
  27. import com.l2jserver.gameserver.model.actor.L2Npc;
  28. import com.l2jserver.gameserver.model.actor.instance.L2FishermanInstance;
  29. import com.l2jserver.gameserver.model.actor.instance.L2NpcInstance;
  30. import com.l2jserver.gameserver.model.actor.instance.L2PcInstance;
  31. import com.l2jserver.gameserver.model.actor.instance.L2TransformManagerInstance;
  32. import com.l2jserver.gameserver.model.actor.instance.L2VillageMasterInstance;
  33. import com.l2jserver.gameserver.model.quest.Quest;
  34. import com.l2jserver.gameserver.network.SystemMessageId;
  35. import com.l2jserver.gameserver.network.serverpackets.ExStorageMaxCount;
  36. import com.l2jserver.gameserver.network.serverpackets.PledgeSkillList;
  37. import com.l2jserver.gameserver.network.serverpackets.ShortCutRegister;
  38. import com.l2jserver.gameserver.network.serverpackets.StatusUpdate;
  39. import com.l2jserver.gameserver.network.serverpackets.SystemMessage;
  40. import com.l2jserver.gameserver.util.Util;
  41. /**
  42. * This class ...
  43. *
  44. * @version $Revision: 1.7.2.1.2.4 $ $Date: 2005/03/27 15:29:30 $
  45. */
  46. public class RequestAquireSkill extends L2GameClientPacket
  47. {
  48. private static final String _C__6C_REQUESTAQUIRESKILL = "[C] 6C RequestAquireSkill";
  49. private static Logger _log = Logger.getLogger(RequestAquireSkill.class.getName());
  50. private int _id;
  51. private int _level;
  52. private int _skillType;
  53. @Override
  54. protected void readImpl()
  55. {
  56. _id = readD();
  57. _level = readD();
  58. _skillType = readD();
  59. }
  60. @Override
  61. protected void runImpl()
  62. {
  63. final L2PcInstance player = getClient().getActiveChar();
  64. if (player == null)
  65. return;
  66. if (_level < 1 || _level > 1000 || _id < 1 || _id > 32000)
  67. {
  68. _log.warning("Recived Wrong Packet Data in Aquired Skill - id:" + _id + " level:" + _level);
  69. return;
  70. }
  71. final L2Npc trainer = player.getLastFolkNPC();
  72. if (!(trainer instanceof L2NpcInstance))
  73. return;
  74. if (!trainer.canInteract(player) && !player.isGM())
  75. return;
  76. if (!Config.ALT_GAME_SKILL_LEARN)
  77. player.setSkillLearningClassId(player.getClassId());
  78. if (player.getSkillLevel(_id) >= _level)
  79. {
  80. // already knows the skill with this level
  81. return;
  82. }
  83. final L2Skill skill = SkillTable.getInstance().getInfo(_id, _level);
  84. int counts = 0;
  85. int _requiredSp = 10000000;
  86. switch (_skillType)
  87. {
  88. case 0:
  89. {
  90. if (trainer instanceof L2TransformManagerInstance) // transform skills
  91. {
  92. int costid = 0;
  93. // Skill Learn bug Fix
  94. L2TransformSkillLearn[] skillst = SkillTreeTable.getInstance().getAvailableTransformSkills(player);
  95. for (L2TransformSkillLearn s : skillst)
  96. {
  97. L2Skill sk = SkillTable.getInstance().getInfo(s.getId(),s.getLevel());
  98. if (sk == null || sk != skill)
  99. continue;
  100. counts++;
  101. costid = s.getItemId();
  102. _requiredSp = s.getSpCost();
  103. }
  104. if (counts == 0)
  105. {
  106. player.sendMessage("You are trying to learn skill that u can't..");
  107. Util.handleIllegalPlayerAction(player, "Player " + player.getName() + " tried to learn skill that he can't!!!", Config.DEFAULT_PUNISH);
  108. return;
  109. }
  110. if (player.getSp() >= _requiredSp)
  111. {
  112. if (!player.destroyItemByItemId("Consume", costid, 1, trainer, false))
  113. {
  114. // Haven't spellbook
  115. player.sendPacket(new SystemMessage(SystemMessageId.ITEM_MISSING_TO_LEARN_SKILL));
  116. return;
  117. }
  118. SystemMessage sm = new SystemMessage(SystemMessageId.S2_S1_DISAPPEARED);
  119. sm.addItemName(costid);
  120. sm.addItemNumber(1);
  121. sendPacket(sm);
  122. sm = null;
  123. }
  124. else
  125. {
  126. SystemMessage sm = new SystemMessage(SystemMessageId.NOT_ENOUGH_SP_TO_LEARN_SKILL);
  127. player.sendPacket(sm);
  128. sm = null;
  129. return;
  130. }
  131. break;
  132. }
  133. // normal skills
  134. L2SkillLearn[] skills = SkillTreeTable.getInstance().getAvailableSkills(player, player.getSkillLearningClassId());
  135. for (L2SkillLearn s : skills)
  136. {
  137. L2Skill sk = SkillTable.getInstance().getInfo(s.getId(),
  138. s.getLevel());
  139. if (sk == null || sk != skill)
  140. continue;
  141. counts++;
  142. _requiredSp = SkillTreeTable.getInstance().getSkillCost(player,skill);
  143. }
  144. if (counts == 0 && !Config.ALT_GAME_SKILL_LEARN)
  145. {
  146. player.sendMessage("You are trying to learn skill that u can't..");
  147. Util.handleIllegalPlayerAction(player, "Player " + player.getName() + " tried to learn skill that he can't!!!", Config.DEFAULT_PUNISH);
  148. return;
  149. }
  150. if (player.getSp() >= _requiredSp)
  151. {
  152. int spbId = -1;
  153. // divine inspiration require book for each level
  154. if (Config.DIVINE_SP_BOOK_NEEDED
  155. && skill.getId() == L2Skill.SKILL_DIVINE_INSPIRATION)
  156. spbId = SkillSpellbookTable.getInstance().getBookForSkill(skill, _level);
  157. else if (Config.SP_BOOK_NEEDED
  158. && skill.getLevel() == 1)
  159. spbId = SkillSpellbookTable.getInstance().getBookForSkill(skill);
  160. // spellbook required
  161. if (spbId > -1)
  162. {
  163. L2ItemInstance spb = player.getInventory().getItemByItemId(spbId);
  164. if (spb == null)
  165. {
  166. // Haven't spellbook
  167. player.sendPacket(new SystemMessage(SystemMessageId.ITEM_MISSING_TO_LEARN_SKILL));
  168. return;
  169. }
  170. // ok
  171. player.destroyItem("Consume", spb.getObjectId(), 1, trainer, true);
  172. }
  173. }
  174. else
  175. {
  176. SystemMessage sm = new SystemMessage(
  177. SystemMessageId.NOT_ENOUGH_SP_TO_LEARN_SKILL);
  178. player.sendPacket(sm);
  179. sm = null;
  180. return;
  181. }
  182. break;
  183. }
  184. case 1:
  185. {
  186. int costid = 0;
  187. int costcount = 0;
  188. // Skill Learn bug Fix
  189. L2SkillLearn[] skillsc = SkillTreeTable.getInstance().getAvailableSkills(player);
  190. for (L2SkillLearn s : skillsc)
  191. {
  192. L2Skill sk = SkillTable.getInstance().getInfo(s.getId(),s.getLevel());
  193. if (sk == null || sk != skill)
  194. continue;
  195. counts++;
  196. costid = s.getIdCost();
  197. costcount = s.getCostCount();
  198. _requiredSp = s.getSpCost();
  199. }
  200. if (counts == 0)
  201. {
  202. player.sendMessage("You are trying to learn skill that u can't..");
  203. Util.handleIllegalPlayerAction(player, "Player " + player.getName() + " tried to learn skill that he can't!!!", Config.DEFAULT_PUNISH);
  204. return;
  205. }
  206. if (player.getSp() >= _requiredSp)
  207. {
  208. if (!player.destroyItemByItemId("Consume", costid, costcount, trainer, false))
  209. {
  210. // Haven't spellbook
  211. player.sendPacket(new SystemMessage(SystemMessageId.ITEM_MISSING_TO_LEARN_SKILL));
  212. return;
  213. }
  214. SystemMessage sm = new SystemMessage(SystemMessageId.S2_S1_DISAPPEARED);
  215. sm.addItemName(costid);
  216. sm.addItemNumber(costcount);
  217. sendPacket(sm);
  218. sm = null;
  219. }
  220. else
  221. {
  222. SystemMessage sm = new SystemMessage(SystemMessageId.NOT_ENOUGH_SP_TO_LEARN_SKILL);
  223. player.sendPacket(sm);
  224. sm = null;
  225. return;
  226. }
  227. break;
  228. }
  229. case 2:
  230. {
  231. if (!player.isClanLeader())
  232. {
  233. // TODO: Find and add system msg
  234. player.sendMessage("This feature is available only for the clan leader");
  235. return;
  236. }
  237. int itemId = 0;
  238. int itemCount = 0;
  239. int repCost = 100000000;
  240. // Skill Learn bug Fix
  241. L2PledgeSkillLearn[] skills = SkillTreeTable.getInstance().getAvailablePledgeSkills(player);
  242. for (L2PledgeSkillLearn s : skills)
  243. {
  244. L2Skill sk = SkillTable.getInstance().getInfo(s.getId(), s.getLevel());
  245. if (sk == null || sk != skill)
  246. continue;
  247. counts++;
  248. itemId = s.getItemId();
  249. itemCount = s.getItemCount();
  250. repCost = s.getRepCost();
  251. }
  252. if (counts == 0)
  253. {
  254. player.sendMessage("You are trying to learn skill that u can't..");
  255. Util.handleIllegalPlayerAction(player, "Player " + player.getName() + " tried to learn skill that he can't!!!", Config.DEFAULT_PUNISH);
  256. return;
  257. }
  258. if (player.getClan().getReputationScore() >= repCost)
  259. {
  260. if (Config.LIFE_CRYSTAL_NEEDED)
  261. {
  262. if (!player.destroyItemByItemId("Consume", itemId, itemCount, trainer, false))
  263. {
  264. // Haven't spellbook
  265. player.sendPacket(new SystemMessage(SystemMessageId.ITEM_MISSING_TO_LEARN_SKILL));
  266. return;
  267. }
  268. SystemMessage sm = new SystemMessage(SystemMessageId.S2_S1_DISAPPEARED);
  269. sm.addItemName(itemId);
  270. sm.addNumber(itemCount);
  271. sendPacket(sm);
  272. sm = null;
  273. }
  274. }
  275. else
  276. {
  277. SystemMessage sm = new SystemMessage(SystemMessageId.ACQUIRE_SKILL_FAILED_BAD_CLAN_REP_SCORE);
  278. player.sendPacket(sm);
  279. return;
  280. }
  281. player.getClan().takeReputationScore(repCost, true);
  282. player.getClan().addNewSkill(skill);
  283. if (Config.DEBUG)
  284. _log.fine("Learned pledge skill " + _id + " for " + _requiredSp + " SP.");
  285. SystemMessage cr = new SystemMessage(SystemMessageId.S1_DEDUCTED_FROM_CLAN_REP);
  286. cr.addNumber(repCost);
  287. player.sendPacket(cr);
  288. SystemMessage sm = new SystemMessage(SystemMessageId.CLAN_SKILL_S1_ADDED);
  289. sm.addSkillName(_id);
  290. player.sendPacket(sm);
  291. sm = null;
  292. player.getClan().broadcastToOnlineMembers(new PledgeSkillList(player.getClan()));
  293. for(L2PcInstance member: player.getClan().getOnlineMembers(0))
  294. {
  295. member.sendSkillList();
  296. }
  297. L2VillageMasterInstance.showPledgeSkillList(player); //Maybe we shoud add a check here...
  298. return;
  299. }
  300. case 4:
  301. {
  302. _requiredSp = 0;
  303. Quest[] qlst = trainer.getTemplate().getEventQuests(Quest.QuestEventType.ON_SKILL_LEARN);
  304. if ((qlst != null) && qlst.length == 1)
  305. {
  306. if (!qlst[0].notifyAcquireSkill(trainer, player, skill))
  307. {
  308. qlst[0].notifyAcquireSkillList(trainer, player);
  309. return;
  310. }
  311. }
  312. else
  313. {
  314. return;
  315. }
  316. break;
  317. }
  318. case 6:
  319. {
  320. int costid = 0;
  321. int costcount = 0;
  322. // Skill Learn bug Fix
  323. L2SkillLearn[] skillsc = SkillTreeTable.getInstance().getAvailableSpecialSkills(player);
  324. for (L2SkillLearn s : skillsc)
  325. {
  326. L2Skill sk = SkillTable.getInstance().getInfo(s.getId(),s.getLevel());
  327. if (sk == null || sk != skill)
  328. continue;
  329. counts++;
  330. costid = s.getIdCost();
  331. costcount = s.getCostCount();
  332. _requiredSp = s.getSpCost();
  333. }
  334. if (counts == 0)
  335. {
  336. player.sendMessage("You are trying to learn skill that u can't..");
  337. Util.handleIllegalPlayerAction(player, "Player " + player.getName() + " tried to learn skill that he can't!!!", Config.DEFAULT_PUNISH);
  338. return;
  339. }
  340. if (player.getSp() >= _requiredSp)
  341. {
  342. if (!player.destroyItemByItemId("Consume", costid, costcount, trainer, false))
  343. {
  344. // Haven't spellbook
  345. player.sendPacket(new SystemMessage(SystemMessageId.ITEM_MISSING_TO_LEARN_SKILL));
  346. return;
  347. }
  348. SystemMessage sm = new SystemMessage(SystemMessageId.S2_S1_DISAPPEARED);
  349. sm.addItemName(costid);
  350. sm.addItemNumber(costcount);
  351. sendPacket(sm);
  352. sm = null;
  353. }
  354. else
  355. {
  356. SystemMessage sm = new SystemMessage(SystemMessageId.NOT_ENOUGH_SP_TO_LEARN_SKILL);
  357. player.sendPacket(sm);
  358. sm = null;
  359. return;
  360. }
  361. break;
  362. }
  363. default:
  364. {
  365. _log.warning("Recived Wrong Packet Data in Aquired Skill - unk1:" + _skillType);
  366. return;
  367. }
  368. }
  369. player.addSkill(skill, true);
  370. if (Config.DEBUG)
  371. _log.fine("Learned skill " + _id + " for " + _requiredSp + " SP.");
  372. player.setSp(player.getSp() - _requiredSp);
  373. StatusUpdate su = new StatusUpdate(player.getObjectId());
  374. su.addAttribute(StatusUpdate.SP, player.getSp());
  375. player.sendPacket(su);
  376. SystemMessage sm = new SystemMessage(SystemMessageId.LEARNED_SKILL_S1);
  377. sm.addSkillName(_id);
  378. player.sendPacket(sm);
  379. sm = null;
  380. // update all the shortcuts to this skill
  381. if (_level > 1)
  382. {
  383. L2ShortCut[] allShortCuts = player.getAllShortCuts();
  384. for (L2ShortCut sc : allShortCuts)
  385. {
  386. if (sc.getId() == _id && sc.getType() == L2ShortCut.TYPE_SKILL)
  387. {
  388. L2ShortCut newsc = new L2ShortCut(sc.getSlot(), sc
  389. .getPage(), sc.getType(), sc.getId(), _level, 1);
  390. player.sendPacket(new ShortCutRegister(newsc));
  391. player.registerShortCut(newsc);
  392. }
  393. }
  394. }
  395. player.sendSkillList();
  396. if (_skillType == 4)
  397. {
  398. Quest[] qlst = trainer.getTemplate().getEventQuests(Quest.QuestEventType.ON_SKILL_LEARN);
  399. qlst[0].notifyAcquireSkillList(trainer, player);
  400. }
  401. else if (trainer instanceof L2FishermanInstance)
  402. L2FishermanInstance.showFishSkillList(player);
  403. else if (trainer instanceof L2TransformManagerInstance)
  404. L2TransformManagerInstance.showTransformSkillList(player);
  405. else
  406. L2NpcInstance.showSkillList(player, trainer, player.getSkillLearningClassId());
  407. if (_id >= 1368 && _id <= 1372) // if skill is expand sendpacket :)
  408. {
  409. ExStorageMaxCount esmc = new ExStorageMaxCount(player);
  410. player.sendPacket(esmc);
  411. }
  412. }
  413. /*
  414. * (non-Javadoc)
  415. *
  416. * @see com.l2jserver.gameserver.clientpackets.ClientBasePacket#getType()
  417. */
  418. @Override
  419. public String getType()
  420. {
  421. return _C__6C_REQUESTAQUIRESKILL;
  422. }
  423. }