예제 #1
0
        public void HandlePacket(Connection conn, PacketIn Packet)
        {
            PacketFunction packetHandler = null;

            if (Packet.Opcode < (ulong)m_packetHandlers.Length)
            {
                packetHandler = m_packetHandlers[Packet.Opcode];
            }
            else
            {
                Log.Error("HandlePacket: ", "Can not handle :" + Packet.Opcode + "(" + Packet.Opcode.ToString("X8") + ")");
            }

            if (packetHandler != null)
            {
                PacketHandlerAttribute[] packethandlerattribs = (PacketHandlerAttribute[])packetHandler.GetType().GetCustomAttributes(typeof(PacketHandlerAttribute), true);

                try
                {
                    packetHandler.Invoke(conn, Packet);
                }
                catch (Exception e)
                {
                    Log.Error("HandlePacket: ", "Packet handler error :" + Packet.Opcode + " " + e.ToString());
                }
            }
            else
            {
                Log.Error("HandlePacket: ", "Can not Handle opcode :" + Packet.Opcode + "(" + Packet.Opcode.ToString("X8") + ")");
            }
        }
예제 #2
0
        public void HandlePacket(BaseClient client, PacketIn Packet)
        {
            if (client == null || Packet == null)
            {
                Log.Error("TCPManager", "Packet || Client == null");
                return;
            }

            PacketFunction packetHandler = null;

            if (Packet.Opcode < (ulong)m_packetHandlers.Length)
            {
                packetHandler = m_packetHandlers[Packet.Opcode];
            }
            else
            {
                Log.Error("TCPManager", "Can not handle :" + Packet.Opcode + "(" + Packet.Opcode.ToString("X8") + ")");
            }

            if (packetHandler != null)
            {
                PacketHandlerAttribute[] packethandlerattribs = (PacketHandlerAttribute[])packetHandler.GetType().GetCustomAttributes(typeof(PacketHandlerAttribute), true);
                if (packethandlerattribs.Length > 0)
                {
                    if (packethandlerattribs[0].State > client.State)
                    {
                        Log.Error("TCPManager", "Can not handle packet (" + Packet.Opcode.ToString("X8") + "), Invalid client state (" + client.GetIp + ")");
                        return;
                    }
                }

                try
                {
                    packetHandler.Invoke(client, Packet);
                }
                catch (Exception e)
                {
                    Log.Error("TCPManager", "Packet handler error :" + Packet.Opcode + " " + e.ToString());
                }
            }
            else
            {
                Log.Error("TCPManager", "Can not Handle opcode :" + Packet.Opcode + "(" + Packet.Opcode.ToString("X8") + ")");
            }
        }