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();
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|