UdpServerEntryPoint.cs 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. using System;
  2. using System.Threading.Tasks;
  3. using Emby.Server.Implementations.Udp;
  4. using MediaBrowser.Controller;
  5. using MediaBrowser.Controller.Plugins;
  6. using MediaBrowser.Model.Net;
  7. using MediaBrowser.Model.Serialization;
  8. using Microsoft.Extensions.Logging;
  9. namespace Emby.Server.Implementations.EntryPoints
  10. {
  11. /// <summary>
  12. /// Class UdpServerEntryPoint
  13. /// </summary>
  14. public class UdpServerEntryPoint : IServerEntryPoint
  15. {
  16. /// <summary>
  17. /// Gets or sets the UDP server.
  18. /// </summary>
  19. /// <value>The UDP server.</value>
  20. private UdpServer UdpServer { get; set; }
  21. /// <summary>
  22. /// The _logger
  23. /// </summary>
  24. private readonly ILogger _logger;
  25. private readonly ISocketFactory _socketFactory;
  26. private readonly IServerApplicationHost _appHost;
  27. private readonly IJsonSerializer _json;
  28. public const int PortNumber = 7359;
  29. /// <summary>
  30. /// Initializes a new instance of the <see cref="UdpServerEntryPoint" /> class.
  31. /// </summary>
  32. public UdpServerEntryPoint(ILogger logger, IServerApplicationHost appHost, IJsonSerializer json, ISocketFactory socketFactory)
  33. {
  34. _logger = logger;
  35. _appHost = appHost;
  36. _json = json;
  37. _socketFactory = socketFactory;
  38. }
  39. /// <summary>
  40. /// Runs this instance.
  41. /// </summary>
  42. public Task RunAsync()
  43. {
  44. var udpServer = new UdpServer(_logger, _appHost, _json, _socketFactory);
  45. try
  46. {
  47. udpServer.Start(PortNumber);
  48. UdpServer = udpServer;
  49. }
  50. catch (Exception ex)
  51. {
  52. _logger.LogError(ex, "Failed to start UDP Server");
  53. }
  54. return Task.CompletedTask;
  55. }
  56. /// <summary>
  57. /// Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources.
  58. /// </summary>
  59. public void Dispose()
  60. {
  61. Dispose(true);
  62. }
  63. /// <summary>
  64. /// Releases unmanaged and - optionally - managed resources.
  65. /// </summary>
  66. /// <param name="dispose"><c>true</c> to release both managed and unmanaged resources; <c>false</c> to release only unmanaged resources.</param>
  67. protected virtual void Dispose(bool dispose)
  68. {
  69. if (dispose)
  70. {
  71. if (UdpServer != null)
  72. {
  73. UdpServer.Dispose();
  74. }
  75. }
  76. }
  77. }
  78. }