Jump to content

giwrgos_

Members
  • Posts

    67
  • Credits

  • Joined

  • Last visited

  • Feedback

    0%

About giwrgos_

Profile Information

  • Gender
    Not Telling

Recent Profile Visitors

The recent visitors block is disabled and is not being shown to other users.

giwrgos_'s Achievements

Apprentice

Apprentice (3/16)

  • Reacting Well Rare
  • First Post Rare
  • Collaborator Rare
  • Dedicated Rare
  • Conversation Starter Rare

Recent Badges

0

Reputation

  1. what info you need please to share?
  2. no error in console oxi kanena error στην κονσολα
  3. καλησπερα μηπως μπωρει καποιο παιδι να μου δωση μια βοηθεια με το autopotion?ενω στο σερβερ πατας το command .autopots και αναβουν τα potions mp hp cp οταν πευτει ενα απο τα τρια δεν λειτουργουν τα potions και αναγκαστικα με κλικ το source ειναι τηs l2r καποια βοηθεια? ευχαριστω good evening, can someone help me with the autopotion? on the server you press the command .autopots and the mp hp cp potions turn on when one of the three drops the potions don't work and I have to click the source is l2r any help ? thanks
  4. καλησπερα μια βοηθεια θα ηθελα εχω προβλημα στο alt+b στο κοματι των raid boss τα image των raid boss δεν τα φορτώνει όλα παρά μόνο μερικά που μπoρει να οφειλετε αυτο? ευχαριστω some pics https://prnt.sc/d15r5rU-QxGR https://prnt.sc/zke1AMDKpoWN https://prnt.sc/sk-L7n8hJPgW
  5. καλησπερα παιδια εχω ενα προβλημα σταματανε να δουλευουν 2 quest το ενα ειναι το noblesse στο κοματι που βγενει το unicon για να συνεχισεις στο επομενο part kai sto 7rb που σταματαει να ριχνει τα κοκαλα μετα το restart φτιαχνουν κανονικα αλλα για 1 ημερα περιπου τι μπoρει να φταιει? δεν μπoρω να καταλαβω τα files ειναι fandc μια βοηθεια?
  6. kalhspera antimetopizw ena problima me to login server enw einai ok kai ton exw valei na kanei auto restart mono o login server ana 12 wres kai enw ola ok meta apo kana 2 meres peytei to login apo mono toy den katalavainw to logo kai sto log toy gameserver kanei sinexeia https://prnt.sc/1mhrgu1 einai apo to log toy gameserver to pack poy exw einai fandc h5 kai o server trexei local gia test episeis exw ton idio se live kai kanei to idio mhpws kapoios mpwrei na me bohthisei na to lisw? tha valw kai to java package l2r.gameserver.network.loginservercon; import java.io.IOException; import java.net.InetSocketAddress; import java.nio.ByteBuffer; import java.nio.ByteOrder; import java.nio.channels.CancelledKeyException; import java.nio.channels.SelectionKey; import java.nio.channels.Selector; import java.nio.channels.SocketChannel; import java.util.ArrayDeque; import java.util.HashMap; import java.util.Iterator; import java.util.Map; import java.util.Queue; import java.util.Set; import java.util.concurrent.atomic.AtomicBoolean; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReadWriteLock; import java.util.concurrent.locks.ReentrantLock; import java.util.concurrent.locks.ReentrantReadWriteLock; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import l2r.gameserver.ThreadPoolManager; import l2r.gameserver.config.templates.HostInfo; import l2r.gameserver.config.xml.holder.HostsConfigHolder; import l2r.gameserver.network.GameClient; import l2r.gameserver.network.loginservercon.gspackets.AuthRequest; public class AuthServerCommunication extends Thread { private static final Logger _log = LoggerFactory.getLogger(AuthServerCommunication.class); private static final AuthServerCommunication instance = new AuthServerCommunication(); public static final AuthServerCommunication getInstance() { return instance; } private final Map<String, GameClient> waitingClients = new HashMap<>(); private final Map<String, GameClient> authedClients = new HashMap<>(); private final ReadWriteLock lock = new ReentrantReadWriteLock(); private final Lock readLock = lock.readLock(); private final Lock writeLock = lock.writeLock(); private final ByteBuffer readBuffer = ByteBuffer.allocate(64 * 1024).order(ByteOrder.LITTLE_ENDIAN); private final ByteBuffer writeBuffer = ByteBuffer.allocate(64 * 1024).order(ByteOrder.LITTLE_ENDIAN); private final Queue<SendablePacket> sendQueue = new ArrayDeque<>(); private final Lock sendLock = new ReentrantLock(); private final AtomicBoolean isPengingWrite = new AtomicBoolean(); private SelectionKey key; private Selector selector; private boolean shutdown; private boolean restart; private AuthServerCommunication() { try { selector = Selector.open(); } catch (IOException e) { _log.error("Error while creating Auth Server Communication!", e); } } private void connect() throws IOException { HostInfo hostInfo = HostsConfigHolder.getInstance().getAuthServerHost(); _log.info("Connecting to authserver on " + hostInfo.getIP() + ":" + hostInfo.getPort()); // _log.info("Connecting to authserver on " + Config.GAME_SERVER_LOGIN_HOST + ":" + Config.GAME_SERVER_LOGIN_PORT); SocketChannel channel = SocketChannel.open(); channel.configureBlocking(false); key = channel.register(selector, SelectionKey.OP_CONNECT); channel.connect(new InetSocketAddress(hostInfo.getIP(), hostInfo.getPort())); // channel.connect(new InetSocketAddress(Config.GAME_SERVER_LOGIN_HOST, Config.GAME_SERVER_LOGIN_PORT)); } public void sendPacket(SendablePacket packet) { if (isShutdown()) { return; } boolean wakeUp; sendLock.lock(); try { sendQueue.add(packet); wakeUp = enableWriteInterest(); } catch (CancelledKeyException e) { return; } finally { sendLock.unlock(); } if (wakeUp) { selector.wakeup(); } } private boolean disableWriteInterest() throws CancelledKeyException { if (isPengingWrite.compareAndSet(true, false)) { key.interestOps(key.interestOps() & ~SelectionKey.OP_WRITE); return true; } return false; } private boolean enableWriteInterest() throws CancelledKeyException { if (isPengingWrite.getAndSet(true) == false) { key.interestOps(key.interestOps() | SelectionKey.OP_WRITE); return true; } return false; } protected ByteBuffer getReadBuffer() { return readBuffer; } protected ByteBuffer getWriteBuffer() { return writeBuffer; } @Override public void run() { Set<SelectionKey> keys; Iterator<SelectionKey> iterator; SelectionKey key; int opts; while (!shutdown) { restart = false; try { loop: while (!isShutdown()) { connect(); selector.select(5000L); keys = selector.selectedKeys(); if (keys.isEmpty()) { throw new IOException("Connection timeout."); } iterator = keys.iterator(); try { while (iterator.hasNext()) { key = iterator.next(); iterator.remove(); opts = key.readyOps(); switch (opts) { case SelectionKey.OP_CONNECT: connect(key); break loop; } } } catch (CancelledKeyException e) { // Exit selector loop break; } } loop: while (!isShutdown()) { selector.select(); keys = selector.selectedKeys(); iterator = keys.iterator(); try { while (iterator.hasNext()) { key = iterator.next(); iterator.remove(); opts = key.readyOps(); switch (opts) { case SelectionKey.OP_WRITE: write(key); break; case SelectionKey.OP_READ: read(key); break; case SelectionKey.OP_READ | SelectionKey.OP_WRITE: write(key); read(key); break; } } } catch (CancelledKeyException e) { // Exit selector loop break loop; } } } catch(IOException e) { _log.info("Loginserver Restart Ore Down Not available, trying to reconnect..."); } close(); try { Thread.sleep(5000L); } catch (InterruptedException e) { } } } private void read(SelectionKey key) throws IOException { SocketChannel channel = (SocketChannel) key.channel(); ByteBuffer buf = getReadBuffer(); int count; count = channel.read(buf); if (count == -1) { throw new IOException("End of stream."); } if (count == 0) { return; } buf.flip(); while (tryReadPacket(key, buf)) { } } private boolean tryReadPacket(SelectionKey key, ByteBuffer buf) throws IOException { int pos = buf.position(); // провер�ем, хватает ли нам байт дл� чтени� заголовка и не пу�того тела пакета if (buf.remaining() > 2) { // получаем ожидаемый размер пакета int size = buf.getShort() & 0xffff; // провер�ем корректно�ть размера if (size <= 2) { throw new IOException("Incorrect packet size: <= 2"); } // ожидаемый размер тела пакета size -= 2; // провер�ем, хватает ли байт на чтение тела if (size <= buf.remaining()) { // apply limit int limit = buf.limit(); buf.limit(pos + size + 2); ReceivablePacket rp = PacketHandler.handlePacket(buf); if (rp != null) { if (rp.read()) { ThreadPoolManager.getInstance().execute(rp); } } buf.limit(limit); buf.position(pos + size + 2); // закончили чтение из буфера, почи�тим if (!buf.hasRemaining()) { buf.clear(); return false; } return true; } // не хватает данных на чтение тела пакета, �бра�ываем позицию buf.position(pos); } buf.compact(); return false; } private void write(SelectionKey key) throws IOException { SocketChannel channel = (SocketChannel) key.channel(); ByteBuffer buf = getWriteBuffer(); boolean done; sendLock.lock(); try { int i = 0; SendablePacket sp; while ((i++ < 64) && ((sp = sendQueue.poll()) != null)) { int headerPos = buf.position(); buf.position(headerPos + 2); sp.write(); int dataSize = buf.position() - headerPos - 2; if (dataSize == 0) { buf.position(headerPos); continue; } // prepend header buf.position(headerPos); buf.putShort((short) (dataSize + 2)); buf.position(headerPos + dataSize + 2); } done = sendQueue.isEmpty(); if (done) { disableWriteInterest(); } } finally { sendLock.unlock(); } buf.flip(); channel.write(buf); if (buf.remaining() > 0) { buf.compact(); done = false; } else { buf.clear(); } if (!done) { if (enableWriteInterest()) { selector.wakeup(); } } } private void connect(SelectionKey key) throws IOException { SocketChannel channel = (SocketChannel) key.channel(); channel.finishConnect(); key.interestOps(key.interestOps() & ~SelectionKey.OP_CONNECT); key.interestOps(key.interestOps() | SelectionKey.OP_READ); sendPacket(new AuthRequest()); } private void close() { restart = !shutdown; sendLock.lock(); try { sendQueue.clear(); } finally { sendLock.unlock(); } readBuffer.clear(); writeBuffer.clear(); isPengingWrite.set(false); try { if (key != null) { key.channel().close(); key.cancel(); } } catch (IOException e) { } writeLock.lock(); try { waitingClients.clear(); } finally { writeLock.unlock(); } } public void shutdown() { shutdown = true; selector.wakeup(); } public boolean isShutdown() { return shutdown || restart; } public void restart() { restart = true; selector.wakeup(); } public GameClient addWaitingClient(GameClient client) { writeLock.lock(); try { return waitingClients.put(client.getLogin(), client); } finally { writeLock.unlock(); } } public GameClient removeWaitingClient(String account) { writeLock.lock(); try { return waitingClients.remove(account); } finally { writeLock.unlock(); } } public GameClient addAuthedClient(GameClient client) { writeLock.lock(); try { return authedClients.put(client.getLogin(), client); } finally { writeLock.unlock(); } } public GameClient removeAuthedClient(String login) { writeLock.lock(); try { return authedClients.remove(login); } finally { writeLock.unlock(); } } public GameClient getAuthedClient(String login) { readLock.lock(); try { return authedClients.get(login); } finally { readLock.unlock(); } } public GameClient removeClient(GameClient client) { writeLock.lock(); try { if (client.isAuthed()) { return authedClients.remove(client.getLogin()); } return waitingClients.remove(client.getSessionKey()); } finally { writeLock.unlock(); } } public String[] getAccounts() { readLock.lock(); try { return authedClients.keySet().toArray(new String[authedClients.size()]); } finally { readLock.unlock(); } } }
  7. to bg to fortonei ok alla den to dixnei se olo to html poy anigeis apo to community mesa sto game dixnei prwta olo to bg kai me scroll kateyeneis kai paei sto html exw kanei poles alages all den katafera tpt https://prnt.sc/1ge96mr https://prnt.sc/1geager https://prnt.sc/1geb2q2
  8. to project pou exw einai fandc sto community mesa sro game exw ena forum douleuei teleia to mono problima einai oti den mpwro na valw ena bg apo utx episeis einai grameno kateytheian sto java kai oxi san html mesa sth data ebala th grammh pou mou eipes alla tpt pali to utx douleuei kanonika giati exw olo to cb mesa
  9. sorry gia to lathos post molis gyrisw apo douleia tha tsekarw ayta pou mou grapsate sas eyxaristw gia th bohtheia pou mou dinete
  10. kalhspera se oloys mia vohtheia ti kanw lathos sthn parakato gramh kai den pairnw to bg mesa sto cb? eyxaristw https://prnt.sc/1fovqrn
  11. yes my friend thats it fix it thank you very much! i have corrupted npcname.dat
  12. fandc project h5 i think the error is from system ..
  13. hello my friends i have some simple erron butt dont remember to fix wen i hit the drakos in dragon valey only this mob in chat the name is noname npc any help? thank you https://prnt.sc/11zod5m
×
×
  • Create New...