/* * This program 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. This program 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 this program. If * not, see <http://www.gnu.org/licenses/>. */ package silentium.authserver.network.clientpackets; import silentium.authserver.network.serverpackets.LoginFail.LoginFailReason; import silentium.authserver.network.serverpackets.ServerList; /** * Format: ddc d: fist part of session id d: second part of session id c: ? */ public class RequestServerList extends L2LoginClientPacket { private int _skey1; private int _skey2; private int _data3; public int getSessionKey1() { return _skey1; } public int getSessionKey2() { return _skey2; } public int getData3() { return _data3; } @Override public boolean readImpl() { if (_buf.remaining() >= 8) { _skey1 = readD(); // loginOk 1 _skey2 = readD(); // loginOk 2 return true; } return false; } @Override public void run() { if (getClient().getSessionKey().checkLoginPair(_skey1, _skey2)) getClient().sendPacket(new ServerList(getClient())); else getClient().close(LoginFailReason.REASON_ACCESS_FAILED); } }