static void Main(string[] args) { Log.Init("proxy"); waiting = new List <Connection>(); Log.Trace("Main", "Connecting to Database"); if (Database.Database.Init() == false) { while (true) { Thread.Sleep(1); } } Log.Debug("Main", "Connected to database sucesfull"); Log.Trace("Main", "Reseting Solar Systems' status"); Log.Trace("Main", "Starting listener on port 26000"); listener = new TCPSocket(26000, false); if (listener.Listen(int.MaxValue) == false) { Log.Error("Main", "Cannot listen on port 26000"); while (true) { ; } } Log.Debug("Main", "Listening on port 26000"); LoginQueue.Start(); // Add two nodes to the NodeManager NodeManager.AddNode(null); NodeManager.AddNode(null); while (true) { Thread.Sleep(1); TCPSocket con = listener.Accept(); if (con != null) { Connection tmp = new Connection(con); tmp.Start(); waiting.Add(tmp); } } }
private PyObject HandleTuple(PyTuple tup) { int items = tup.Items.Count; if (items == 6) { // Only LowLeverVersionExchange if (CheckLowLevelVersionExchange(tup) == false) { Close(); } if (isNode) { // We are a node, the next packets will be handled by the Node class Node n = new Node(new StreamPacketizer(), socket); NodeManager.AddNode(n); forClose = false; Close(); } return(null); } else if (items == 3) { if (tup.Items[0].Type == PyObjectType.None) { // VipKey VipKeyCommand vk = new VipKeyCommand(); if (vk.Decode(tup) == false) { Log.Error("Client", "Wrong vipKey command"); Close(); return(null); } return(null); } else { // Handshake sent when we are mostly in HandshakeAck ack = new HandshakeAck(); ack.live_updates = new PyList(); ack.jit = session.GetCurrentString("languageID"); ack.userid = session.GetCurrentInt("userid"); ack.maxSessionTime = new PyNone(); ack.userType = Common.Constants.AccountType.User; ack.role = session.GetCurrentInt("role"); ack.address = session.GetCurrentString("address"); ack.inDetention = new PyNone(); ack.client_hashes = new PyList(); ack.user_clientid = session.GetCurrentInt("userid"); // We have to send this just before the sessionchange Send(ack.Encode()); // Create the client instance Client cli = new Client(new StreamPacketizer(), socket); // Update the Client class session data cli.InitialSession(session); // Set the node id for the client cli.SetNodeID(nodeID); // Send session change cli.SendSessionChange(); // Start the client packet reader thread cli.Start(); // Now we are completely in, add us to the list ClientManager.AddClient(cli); // Delete ourselves from the list forClose = false; Close(); } } else if (items == 2) // PlaceboRequest, QueueCheck and Login packet { if (tup.Items[0].Type == PyObjectType.None) { QueueCheckCommand qc = new QueueCheckCommand(); if (qc.Decode(tup) == false) { Log.Error("Client", "Wrong QueueCheck command"); Close(); return(null); } // Queued logins Send(new PyInt(LoginQueue.queue.Count + 1)); SendLowLevelVersionExchange(); return(null); } else if (tup.Items[0].Type == PyObjectType.String) { if (tup.Items[0].As <PyString>().Value == "placebo") { // We assume it is a placebo request PlaceboRequest req = new PlaceboRequest(); if (req.Decode(tup) == false) { Log.Error("Client", "Wrong placebo request"); Close(); return(null); } return(new PyString("OK CC")); } else { // Check if the password is hashed or not and ask for plain password AuthenticationReq req = new AuthenticationReq(); if (req.Decode(tup) == false) { Log.Error("Client", "Wrong login packet"); GPSTransportClosed ex = new GPSTransportClosed("LoginAuthFailed"); Send(ex.Encode()); Close(); return(null); } // The hash is in sha1, we should handle it later if (req.user_password == null) { Log.Trace("Client", "Rejected by server; requesting plain password"); return(new PyInt(1)); // Ask for unhashed password( 1 -> Plain, 2 -> Hashed ) } request = req; // Login request, add it to the queue and wait until we are accepted or rejected LoginQueue.Enqueue(this); // The login queue will call send the data to the client return(null); } } } else { Log.Error("Connection", "Unhandled Tuple packet with " + items + " items"); thr.Abort(); return(null); } return(null); }