64 lines
2.5 KiB
C#
Raw Normal View History

2018-12-25 22:12:37 +01:00
using System.Collections.Generic;
2018-12-25 17:08:43 +01:00
using System.Net;
using System.Net.Sockets;
using System.Threading.Tasks;
namespace Syroot.Worms.OnlineWorms.Server
{
/// <summary>
/// Represents a server listening for incoming client connections and dispatching them into <see cref="Client"/>
/// instances.
/// </summary>
2018-12-25 22:12:37 +01:00
internal class Server
2018-12-25 17:08:43 +01:00
{
// ---- FIELDS -------------------------------------------------------------------------------------------------
private readonly List<Client> _clients = new List<Client>();
2018-12-25 22:12:37 +01:00
// ---- PROPERTIES ---------------------------------------------------------------------------------------------
internal string Name => "Online Worms Private Server";
internal string RegionName => "Global";
internal ushort Version => 114;
2019-01-03 21:48:31 +01:00
/// <summary>
/// Gets the port under which the server listens for new connections.
/// </summary>
internal int Port { get; private set; }
2018-12-25 22:12:37 +01:00
internal Log Log { get; } = new Log();
2018-12-25 17:08:43 +01:00
// ---- METHODS (INTERNAL) -------------------------------------------------------------------------------------
/// <summary>
/// Starts the server by accepting new client connections under the given <paramref name="port"/> and
/// dispatching them into asynchronous handling threads. This call is blocking.
/// </summary>
/// <param name="port">The port on which to listen for new client connections.</param>
internal void Listen(int port)
{
2019-01-03 21:48:31 +01:00
Port = port;
TcpListener tcpListener = new TcpListener(IPAddress.Any, Port);
2018-12-25 17:08:43 +01:00
tcpListener.Start();
2019-01-03 21:48:31 +01:00
Log.Write(LogCategory.Server, $"Listening on port {Port}...");
2018-12-25 17:08:43 +01:00
while (true)
{
2018-12-25 22:12:37 +01:00
// Continually accept clients.
TcpClient tcpClient = tcpListener.AcceptTcpClient();
Log.Write(LogCategory.Connect, $"{tcpClient.Client.RemoteEndPoint} connected");
Client client = new Client(tcpClient, this);
2018-12-25 17:08:43 +01:00
_clients.Add(client);
2018-12-25 22:12:37 +01:00
// Dispatch the client into its listening thread and remove it when listening aborts.
2018-12-25 17:36:36 +01:00
Task.Run(client.Listen).ContinueWith(_ =>
2018-12-25 17:08:43 +01:00
{
2018-12-25 22:12:37 +01:00
Log.Write(LogCategory.Disconnect, $"{client.TcpClient.Client.RemoteEndPoint} disconnected");
2018-12-25 17:08:43 +01:00
_clients.Remove(client);
client.Dispose();
});
}
}
}
}