jellyfin-server/Emby.Server.Implementations/EntryPoints/UdpServerEntryPoint.cs

89 lines
2.6 KiB
C#
Raw Normal View History

using System;
2019-01-27 14:40:37 +00:00
using System.Threading.Tasks;
using Emby.Server.Implementations.Udp;
2014-07-27 22:01:29 +00:00
using MediaBrowser.Controller;
2013-05-18 22:07:59 +00:00
using MediaBrowser.Controller.Plugins;
2016-11-04 18:56:47 +00:00
using MediaBrowser.Model.Net;
using MediaBrowser.Model.Serialization;
using Microsoft.Extensions.Logging;
2013-05-18 22:07:59 +00:00
2016-11-04 18:56:47 +00:00
namespace Emby.Server.Implementations.EntryPoints
2013-05-18 22:07:59 +00:00
{
/// <summary>
/// Class UdpServerEntryPoint
/// </summary>
2013-05-18 22:07:59 +00:00
public class UdpServerEntryPoint : IServerEntryPoint
{
/// <summary>
/// Gets or sets the UDP server.
/// </summary>
/// <value>The UDP server.</value>
private UdpServer UdpServer { get; set; }
/// <summary>
/// The _logger
/// </summary>
2013-05-18 22:07:59 +00:00
private readonly ILogger _logger;
2016-11-04 18:56:47 +00:00
private readonly ISocketFactory _socketFactory;
2014-07-27 22:01:29 +00:00
private readonly IServerApplicationHost _appHost;
2014-07-30 03:31:35 +00:00
private readonly IJsonSerializer _json;
2013-05-18 22:07:59 +00:00
2013-09-25 00:54:51 +00:00
public const int PortNumber = 7359;
/// <summary>
2014-08-19 22:28:35 +00:00
/// Initializes a new instance of the <see cref="UdpServerEntryPoint" /> class.
/// </summary>
2016-11-04 18:56:47 +00:00
public UdpServerEntryPoint(ILogger logger, IServerApplicationHost appHost, IJsonSerializer json, ISocketFactory socketFactory)
2013-05-18 22:07:59 +00:00
{
_logger = logger;
2014-07-27 22:01:29 +00:00
_appHost = appHost;
2014-07-30 03:31:35 +00:00
_json = json;
2016-11-04 18:56:47 +00:00
_socketFactory = socketFactory;
2013-05-18 22:07:59 +00:00
}
/// <summary>
/// Runs this instance.
/// </summary>
2019-01-27 14:40:37 +00:00
public Task RunAsync()
2013-05-18 22:07:59 +00:00
{
2016-11-04 18:56:47 +00:00
var udpServer = new UdpServer(_logger, _appHost, _json, _socketFactory);
2013-05-18 22:07:59 +00:00
try
{
2013-09-25 00:54:51 +00:00
udpServer.Start(PortNumber);
2013-05-18 22:07:59 +00:00
UdpServer = udpServer;
}
2016-11-04 14:09:21 +00:00
catch (Exception ex)
2013-05-18 22:07:59 +00:00
{
2018-12-20 12:11:26 +00:00
_logger.LogError(ex, "Failed to start UDP Server");
2013-05-18 22:07:59 +00:00
}
2019-01-27 14:40:37 +00:00
return Task.CompletedTask;
2013-05-18 22:07:59 +00:00
}
/// <summary>
/// Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources.
/// </summary>
2013-05-18 22:07:59 +00:00
public void Dispose()
{
Dispose(true);
}
/// <summary>
/// Releases unmanaged and - optionally - managed resources.
/// </summary>
/// <param name="dispose"><c>true</c> to release both managed and unmanaged resources; <c>false</c> to release only unmanaged resources.</param>
2013-05-18 22:07:59 +00:00
protected virtual void Dispose(bool dispose)
{
if (dispose)
{
if (UdpServer != null)
{
UdpServer.Dispose();
}
}
}
}
}