68 lines
2.6 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;
2019-01-04 19:14:55 +01:00
using Microsoft.Extensions.Configuration;
2018-12-25 17:08:43 +01:00
2019-01-12 22:02:35 +01:00
namespace Syroot.Worms.Mgame.Server
2018-12-25 17:08:43 +01:00
{
/// <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>();
2019-01-04 19:14:55 +01:00
// ---- CONSTRUCTORS & DESTRUCTOR ------------------------------------------------------------------------------
2018-12-25 22:12:37 +01:00
2019-01-04 19:14:55 +01:00
internal Server()
{
// Create and read the configuration.
Config = new ConfigurationBuilder()
.AddJsonFile("OWServerConfig.json", true)
.Build()
.Get<Config>();
}
2018-12-25 22:12:37 +01:00
2019-01-04 19:14:55 +01:00
// ---- PROPERTIES ---------------------------------------------------------------------------------------------
internal Config Config { get; }
2019-01-03 21:48:31 +01:00
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>
2019-01-04 19:14:55 +01:00
internal void Listen()
2018-12-25 17:08:43 +01:00
{
2019-01-04 19:14:55 +01:00
TcpListener tcpListener = new TcpListener(IPAddress.Any, Config.Port);
2018-12-25 17:08:43 +01:00
tcpListener.Start();
2019-01-04 19:14:55 +01:00
Log.Write(LogCategory.Server, $"Listening on {Config.EndPoint}...");
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();
});
}
}
}
}