PageRenderTime 42ms CodeModel.GetById 16ms RepoModel.GetById 0ms app.codeStats 0ms

/Trunk/src/net/sf/odinms/net/channel/handler/MovePlayerHandler.java

https://github.com/system32/NinjaMS
Java | 95 lines | 60 code | 12 blank | 23 comment | 17 complexity | 79ff51bb759836162a3744302068bf9b MD5 | raw file
Possible License(s): AGPL-3.0
  1. /*
  2. This file is part of the OdinMS Maple Story Server
  3. Copyright (C) 2008 Patrick Huy <patrick.huy@frz.cc>
  4. Matthias Butz <matze@odinms.de>
  5. Jan Christian Meyer <vimes@odinms.de>
  6. This program is free software: you can redistribute it and/or modify
  7. it under the terms of the GNU Affero General Public License version 3
  8. as published by the Free Software Foundation. You may not use, modify
  9. or distribute this program under any other version of the
  10. GNU Affero General Public License.
  11. This program is distributed in the hope that it will be useful,
  12. but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. GNU Affero General Public License for more details.
  15. You should have received a copy of the GNU Affero General Public License
  16. along with this program. If not, see <http://www.gnu.org/licenses/>.
  17. */
  18. package net.sf.odinms.net.channel.handler;
  19. import java.util.List;
  20. import net.sf.odinms.client.Clones;
  21. import net.sf.odinms.client.MapleCharacter;
  22. import net.sf.odinms.client.MapleClient;
  23. import net.sf.odinms.net.MaplePacket;
  24. import net.sf.odinms.server.TimerManager;
  25. import net.sf.odinms.server.constants.SpecialStuff;
  26. import net.sf.odinms.server.movement.LifeMovementFragment;
  27. import net.sf.odinms.tools.MaplePacketCreator;
  28. import net.sf.odinms.tools.data.input.SeekableLittleEndianAccessor;
  29. import org.slf4j.Logger;
  30. import org.slf4j.LoggerFactory;
  31. public class MovePlayerHandler extends AbstractMovementPacketHandler {
  32. private static Logger log = LoggerFactory.getLogger(MovePlayerHandler.class);
  33. @Override
  34. public void handlePacket(SeekableLittleEndianAccessor slea, MapleClient c) {
  35. slea.readByte();
  36. slea.readInt();
  37. slea.readInt();
  38. // log.trace("Movement command received: unk1 {} unk2 {}", new Object[] { unk1, unk2 });
  39. final List<LifeMovementFragment> res = parseMovement(slea);
  40. // TODO more validation of input data
  41. if (res != null) {
  42. if (slea.available() != 18) {
  43. // log.warn("slea.available != 18 (movement parsing error)");
  44. return;
  45. }
  46. MapleCharacter player = c.getPlayer();
  47. if(player.getJobId() == 900 || player.getJobId() == 910 ){
  48. if(!player.isJounin() && player.getMapId() != 100000000){
  49. player.changeJobById(0);
  50. player.goHome();
  51. }
  52. }
  53. if(!player.isChunin() && SpecialStuff.getInstance().isDojoMap(player.getMapId()) && (player.getGMSMode() < 1)){
  54. player.goHome();
  55. player.dropMessage("You can only be in Dojo if you are in GMS mode");
  56. }
  57. if (!player.isHidden()) {
  58. MaplePacket packet = MaplePacketCreator.movePlayer(player.getId(), res);
  59. c.getPlayer().getMap().broadcastMessage(player, packet, false);
  60. }
  61. updatePosition(res, c.getPlayer(), 0);
  62. c.getPlayer().getMap().movePlayer(c.getPlayer(), c.getPlayer().getPosition());
  63. if (c.getPlayer().hasClones()) {
  64. int i = 1;
  65. for (final Clones clone : c.getPlayer().getClones()) {
  66. TimerManager.getInstance().schedule(new Runnable() {
  67. @Override
  68. public void run() {
  69. MaplePacket packet = MaplePacketCreator.movePlayer(clone.getClone().getId(), res);
  70. clone.getClone().getMap().broadcastMessage(clone.getClone(), packet, false);
  71. updatePosition(res, clone.getClone(), 0);
  72. clone.getClone().getMap().movePlayer(clone.getClone(), clone.getClone().getPosition());
  73. }
  74. }, i * 250);
  75. i++;
  76. }
  77. }
  78. }
  79. }
  80. }