/** * This file is part of aion-emu <aion-emu.com>. * * aion-emu is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * aion-emu is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with aion-emu. If not, see <http://www.gnu.org/licenses/>. */ package com.aionemu.loginserver.network.aion; import com.aionemu.loginserver.network.aion.AionConnection.State; import com.aionemu.loginserver.network.aion.clientpackets.CM_AUTH_GG; import com.aionemu.loginserver.network.aion.clientpackets.CM_LOGIN; import com.aionemu.loginserver.network.aion.clientpackets.CM_PLAY; import com.aionemu.loginserver.network.aion.clientpackets.CM_SERVER_LIST; import com.aionemu.loginserver.network.aion.clientpackets.CM_UPDATE_SESSION; import org.apache.log4j.Logger; import java.nio.ByteBuffer; /** * @author -Nemesiss- */ public class AionPacketHandler { /** * logger for this class */ private static final Logger log = Logger.getLogger(AionPacketHandler.class); /** * Reads one packet from given ByteBuffer * * @param data * @param client * @return AionClientPacket object from binary data */ public static AionClientPacket handle(ByteBuffer data, AionConnection client) { AionClientPacket msg = null; State state = client.getState(); int id = data.get() & 0xff; switch (state) { case CONNECTED: { switch (id) { case 0x07: msg = new CM_AUTH_GG(data, client); break; case 0x08: msg = new CM_UPDATE_SESSION(data, client); break; default: unknownPacket(state, id); } break; } case AUTHED_GG: { switch (id) { case 0x0B: msg = new CM_LOGIN(data, client); break; default: unknownPacket(state, id); } break; } case AUTHED_LOGIN: { switch (id) { case 0x05: msg = new CM_SERVER_LIST(data, client); break; case 0x02: msg = new CM_PLAY(data, client); break; default: unknownPacket(state, id); } break; } } return msg; } /** * Logs unknown packet. * * @param state * @param id */ private static void unknownPacket(State state, int id) { log.warn(String.format("Unknown packet recived from Aion client: 0x%02X state=%s", id, state.toString())); } }