Files
Ragon/Ragon.Core/Application.cs
T

101 lines
2.6 KiB
C#
Raw Normal View History

2022-12-16 00:05:46 +04:00
using System.Diagnostics;
using NLog;
using Ragon.Common;
using Ragon.Core.Lobby;
using Ragon.Core.Time;
using Ragon.Server;
using Ragon.Server.ENet;
namespace Ragon.Core;
public class Application : INetworkListener
{
2022-12-16 23:36:51 +04:00
private readonly Logger _logger = LogManager.GetCurrentClassLogger();
private readonly INetworkServer _server;
private readonly Thread _dedicatedThread;
private readonly Configuration _configuration;
private readonly HandlerRegistry _handlerRegistry;
private readonly ILobby _lobby;
private readonly Loop _loop;
private readonly Dictionary<ushort, PlayerContext> _contexts;
2022-12-16 00:05:46 +04:00
public Application(Configuration configuration)
{
_configuration = configuration;
_dedicatedThread = new Thread(Execute);
_dedicatedThread.IsBackground = true;
2022-12-16 23:36:51 +04:00
_contexts = new Dictionary<ushort, PlayerContext>();
2022-12-16 00:05:46 +04:00
_handlerRegistry = new HandlerRegistry();
_lobby = new LobbyInMemory();
2022-12-16 23:36:51 +04:00
_loop = new Loop();
2022-12-16 00:05:46 +04:00
if (configuration.Socket == "enet")
_server = new ENetServer();
Debug.Assert(_server != null, $"Socket type not supported: {configuration.Socket}. Supported: [enet, websocket]");
}
public void Execute()
{
while (true)
{
2022-12-16 23:36:51 +04:00
_loop.Tick();
2022-12-16 00:05:46 +04:00
_server.Poll();
Thread.Sleep((int) 1000.0f / _configuration.SendRate);
}
}
public void Start()
{
var networkConfiguration = new NetworkConfiguration()
{
LimitConnections = _configuration.LimitConnections,
Protocol = RagonVersion.Parse(_configuration.Protocol),
Address = "0.0.0.0",
Port = _configuration.Port,
};
_server.Start(this, networkConfiguration);
_dedicatedThread.Start();
}
public void Stop()
{
_server.Stop();
_dedicatedThread.Interrupt();
}
public void OnConnected(INetworkConnection connection)
{
var context = new PlayerContext(connection, new LobbyPlayer(connection));
context.Lobby = _lobby;
2022-12-16 23:36:51 +04:00
context.Loop = _loop;
2022-12-16 00:05:46 +04:00
_logger.Trace($"Connected {connection.Id}");
_contexts.Add(connection.Id, context);
}
public void OnDisconnected(INetworkConnection connection)
{
_logger.Trace($"Disconnected {connection.Id}");
if (_contexts.Remove(connection.Id, out var context))
{
context.Room?.RemovePlayer(context.RoomPlayer);
context.Dispose();
}
}
public void OnTimeout(INetworkConnection connection)
{
if (_contexts.Remove(connection.Id, out var context))
context.Dispose();
}
public void OnData(INetworkConnection connection, byte[] data)
{
if (_contexts.TryGetValue(connection.Id, out var context))
_handlerRegistry.Handle(context, data);
}
}