Selaa lähdekoodia

Move LiveTv to separate project

Patrick Barron 1 vuosi sitten
vanhempi
sitoutus
c1a3084312
78 muutettua tiedostoa jossa 121 lisäystä ja 85 poistoa
  1. 0 4
      Emby.Server.Implementations/ApplicationHost.cs
  2. 0 1
      Emby.Server.Implementations/Emby.Server.Implementations.csproj
  3. 0 1
      Emby.Server.Implementations/Properties/AssemblyInfo.cs
  4. 8 0
      Jellyfin.Server/CoreAppHost.cs
  5. 1 0
      Jellyfin.Server/Jellyfin.Server.csproj
  6. 7 0
      Jellyfin.sln
  7. 1 2
      src/Jellyfin.LiveTv/EmbyTV/DirectRecorder.cs
  8. 1 3
      src/Jellyfin.LiveTv/EmbyTV/EmbyTV.cs
  9. 1 1
      src/Jellyfin.LiveTv/EmbyTV/EncodedRecorder.cs
  10. 1 1
      src/Jellyfin.LiveTv/EmbyTV/EntryPoint.cs
  11. 1 1
      src/Jellyfin.LiveTv/EmbyTV/EpgChannelData.cs
  12. 1 1
      src/Jellyfin.LiveTv/EmbyTV/IRecorder.cs
  13. 1 1
      src/Jellyfin.LiveTv/EmbyTV/ItemDataProvider.cs
  14. 1 1
      src/Jellyfin.LiveTv/EmbyTV/NfoConfigurationExtensions.cs
  15. 1 1
      src/Jellyfin.LiveTv/EmbyTV/RecordingHelper.cs
  16. 1 1
      src/Jellyfin.LiveTv/EmbyTV/SeriesTimerManager.cs
  17. 1 1
      src/Jellyfin.LiveTv/EmbyTV/TimerManager.cs
  18. 2 1
      src/Jellyfin.LiveTv/ExclusiveLiveStream.cs
  19. 22 0
      src/Jellyfin.LiveTv/Jellyfin.LiveTv.csproj
  20. 4 2
      src/Jellyfin.LiveTv/Listings/SchedulesDirect.cs
  21. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/BroadcasterDto.cs
  22. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/CaptionDto.cs
  23. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/CastDto.cs
  24. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/ChannelDto.cs
  25. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/ContentRatingDto.cs
  26. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/CrewDto.cs
  27. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/DayDto.cs
  28. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/Description1000Dto.cs
  29. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/Description100Dto.cs
  30. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/DescriptionsProgramDto.cs
  31. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/EventDetailsDto.cs
  32. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/GracenoteDto.cs
  33. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/HeadendsDto.cs
  34. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/ImageDataDto.cs
  35. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/LineupDto.cs
  36. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/LineupsDto.cs
  37. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/LogoDto.cs
  38. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/MapDto.cs
  39. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/MetadataDto.cs
  40. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/MetadataProgramsDto.cs
  41. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/MetadataScheduleDto.cs
  42. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/MovieDto.cs
  43. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/MultipartDto.cs
  44. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/ProgramDetailsDto.cs
  45. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/ProgramDto.cs
  46. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/QualityRatingDto.cs
  47. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/RatingDto.cs
  48. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/RecommendationDto.cs
  49. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/RequestScheduleForChannelDto.cs
  50. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/ShowImagesDto.cs
  51. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/StationDto.cs
  52. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/TitleDto.cs
  53. 1 1
      src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/TokenDto.cs
  54. 1 1
      src/Jellyfin.LiveTv/Listings/XmlTvListingsProvider.cs
  55. 1 1
      src/Jellyfin.LiveTv/LiveTvConfigurationFactory.cs
  56. 1 1
      src/Jellyfin.LiveTv/LiveTvDtoService.cs
  57. 3 2
      src/Jellyfin.LiveTv/LiveTvManager.cs
  58. 1 1
      src/Jellyfin.LiveTv/LiveTvMediaSourceProvider.cs
  59. 1 1
      src/Jellyfin.LiveTv/RefreshGuideScheduledTask.cs
  60. 1 1
      src/Jellyfin.LiveTv/TunerHosts/BaseTunerHost.cs
  61. 1 1
      src/Jellyfin.LiveTv/TunerHosts/HdHomerun/Channels.cs
  62. 1 1
      src/Jellyfin.LiveTv/TunerHosts/HdHomerun/DiscoverResponse.cs
  63. 1 1
      src/Jellyfin.LiveTv/TunerHosts/HdHomerun/HdHomerunChannelCommands.cs
  64. 4 4
      src/Jellyfin.LiveTv/TunerHosts/HdHomerun/HdHomerunHost.cs
  65. 1 1
      src/Jellyfin.LiveTv/TunerHosts/HdHomerun/HdHomerunManager.cs
  66. 2 1
      src/Jellyfin.LiveTv/TunerHosts/HdHomerun/HdHomerunUdpStream.cs
  67. 1 1
      src/Jellyfin.LiveTv/TunerHosts/HdHomerun/IHdHomerunChannelCommands.cs
  68. 1 1
      src/Jellyfin.LiveTv/TunerHosts/HdHomerun/LegacyHdHomerunChannelCommands.cs
  69. 2 1
      src/Jellyfin.LiveTv/TunerHosts/LiveStream.cs
  70. 1 1
      src/Jellyfin.LiveTv/TunerHosts/M3UTunerHost.cs
  71. 1 1
      src/Jellyfin.LiveTv/TunerHosts/M3uParser.cs
  72. 2 1
      src/Jellyfin.LiveTv/TunerHosts/SharedHttpStream.cs
  73. 1 1
      tests/Jellyfin.LiveTv.Tests/HdHomerunHostTests.cs
  74. 1 1
      tests/Jellyfin.LiveTv.Tests/HdHomerunManagerTests.cs
  75. 1 1
      tests/Jellyfin.LiveTv.Tests/Jellyfin.LiveTv.Tests.csproj
  76. 1 1
      tests/Jellyfin.LiveTv.Tests/Listings/XmlTvListingsProviderTests.cs
  77. 1 1
      tests/Jellyfin.LiveTv.Tests/RecordingHelperTests.cs
  78. 1 1
      tests/Jellyfin.LiveTv.Tests/SchedulesDirect/SchedulesDirectDeserializeTests.cs

+ 0 - 4
Emby.Server.Implementations/ApplicationHost.cs

@@ -25,7 +25,6 @@ using Emby.Server.Implementations.Dto;
 using Emby.Server.Implementations.HttpServer.Security;
 using Emby.Server.Implementations.IO;
 using Emby.Server.Implementations.Library;
-using Emby.Server.Implementations.LiveTv;
 using Emby.Server.Implementations.Localization;
 using Emby.Server.Implementations.Playlists;
 using Emby.Server.Implementations.Plugins;
@@ -567,9 +566,6 @@ namespace Emby.Server.Implementations
 
             serviceCollection.AddSingleton<ISyncPlayManager, SyncPlayManager>();
 
-            serviceCollection.AddSingleton<LiveTvDtoService>();
-            serviceCollection.AddSingleton<ILiveTvManager, LiveTvManager>();
-
             serviceCollection.AddSingleton<IUserViewManager, UserViewManager>();
 
             serviceCollection.AddSingleton<IChapterManager, ChapterManager>();

+ 0 - 1
Emby.Server.Implementations/Emby.Server.Implementations.csproj

@@ -22,7 +22,6 @@
 
   <ItemGroup>
     <PackageReference Include="DiscUtils.Udf" />
-    <PackageReference Include="Jellyfin.XmlTv" />
     <PackageReference Include="Microsoft.Data.Sqlite" />
     <PackageReference Include="Microsoft.Extensions.DependencyInjection" />
     <PackageReference Include="Microsoft.Extensions.Caching.Memory" />

+ 0 - 1
Emby.Server.Implementations/Properties/AssemblyInfo.cs

@@ -17,7 +17,6 @@ using System.Runtime.InteropServices;
 [assembly: NeutralResourcesLanguage("en")]
 [assembly: InternalsVisibleTo("Jellyfin.Server.Implementations.Tests")]
 [assembly: InternalsVisibleTo("Emby.Server.Implementations.Fuzz")]
-[assembly: InternalsVisibleTo("Jellyfin.LiveTv.Tests")]
 
 // Setting ComVisible to false makes the types in this assembly not visible
 // to COM components.  If you need to access a type in this assembly from

+ 8 - 0
Jellyfin.Server/CoreAppHost.cs

@@ -6,6 +6,7 @@ using Emby.Server.Implementations.Session;
 using Jellyfin.Api.WebSocketListeners;
 using Jellyfin.Drawing;
 using Jellyfin.Drawing.Skia;
+using Jellyfin.LiveTv;
 using Jellyfin.Server.Implementations;
 using Jellyfin.Server.Implementations.Activity;
 using Jellyfin.Server.Implementations.Devices;
@@ -20,6 +21,7 @@ using MediaBrowser.Controller.Devices;
 using MediaBrowser.Controller.Drawing;
 using MediaBrowser.Controller.Events;
 using MediaBrowser.Controller.Library;
+using MediaBrowser.Controller.LiveTv;
 using MediaBrowser.Controller.Lyrics;
 using MediaBrowser.Controller.Net;
 using MediaBrowser.Controller.Security;
@@ -96,6 +98,9 @@ namespace Jellyfin.Server
 
             serviceCollection.AddScoped<IAuthenticationManager, AuthenticationManager>();
 
+            serviceCollection.AddSingleton<LiveTvDtoService>();
+            serviceCollection.AddSingleton<ILiveTvManager, LiveTvManager>();
+
             foreach (var type in GetExportTypes<ILyricProvider>())
             {
                 serviceCollection.AddSingleton(typeof(ILyricProvider), type);
@@ -117,6 +122,9 @@ namespace Jellyfin.Server
 
             // Jellyfin.Server.Implementations
             yield return typeof(JellyfinDbContext).Assembly;
+
+            // Jellyfin.LiveTv
+            yield return typeof(LiveTvManager).Assembly;
         }
     }
 }

+ 1 - 0
Jellyfin.Server/Jellyfin.Server.csproj

@@ -58,6 +58,7 @@
     <ProjectReference Include="..\src\Jellyfin.Drawing\Jellyfin.Drawing.csproj" />
     <ProjectReference Include="..\Emby.Server.Implementations\Emby.Server.Implementations.csproj" />
     <ProjectReference Include="..\src\Jellyfin.Drawing.Skia\Jellyfin.Drawing.Skia.csproj" />
+    <ProjectReference Include="..\src\Jellyfin.LiveTv\Jellyfin.LiveTv.csproj" />
     <ProjectReference Include="..\Jellyfin.Server.Implementations\Jellyfin.Server.Implementations.csproj" />
     <ProjectReference Include="..\src\Jellyfin.MediaEncoding.Hls\Jellyfin.MediaEncoding.Hls.csproj" />
   </ItemGroup>

+ 7 - 0
Jellyfin.sln

@@ -89,6 +89,8 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Jellyfin.MediaEncoding.Keyf
 EndProject
 Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Jellyfin.LiveTv.Tests", "tests\Jellyfin.LiveTv.Tests\Jellyfin.LiveTv.Tests.csproj", "{C4F71272-C6BE-4C30-BE0D-4E6ED651D6D3}"
 EndProject
+Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Jellyfin.LiveTv", "src\Jellyfin.LiveTv\Jellyfin.LiveTv.csproj", "{8C6B2B13-58A4-4506-9DAB-1F882A093FE0}"
+EndProject
 Global
 	GlobalSection(SolutionConfigurationPlatforms) = preSolution
 		Debug|Any CPU = Debug|Any CPU
@@ -239,6 +241,10 @@ Global
 		{C4F71272-C6BE-4C30-BE0D-4E6ED651D6D3}.Debug|Any CPU.Build.0 = Debug|Any CPU
 		{C4F71272-C6BE-4C30-BE0D-4E6ED651D6D3}.Release|Any CPU.ActiveCfg = Release|Any CPU
 		{C4F71272-C6BE-4C30-BE0D-4E6ED651D6D3}.Release|Any CPU.Build.0 = Release|Any CPU
+		{8C6B2B13-58A4-4506-9DAB-1F882A093FE0}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
+		{8C6B2B13-58A4-4506-9DAB-1F882A093FE0}.Debug|Any CPU.Build.0 = Debug|Any CPU
+		{8C6B2B13-58A4-4506-9DAB-1F882A093FE0}.Release|Any CPU.ActiveCfg = Release|Any CPU
+		{8C6B2B13-58A4-4506-9DAB-1F882A093FE0}.Release|Any CPU.Build.0 = Release|Any CPU
 	EndGlobalSection
 	GlobalSection(SolutionProperties) = preSolution
 		HideSolutionNode = FALSE
@@ -266,6 +272,7 @@ Global
 		{154872D9-6C12-4007-96E3-8F70A58386CE} = {C9F0AB5D-F4D7-40C8-A353-3305C86D6D4C}
 		{0A3FCC4D-C714-4072-B90F-E374A15F9FF9} = {C9F0AB5D-F4D7-40C8-A353-3305C86D6D4C}
 		{C4F71272-C6BE-4C30-BE0D-4E6ED651D6D3} = {FBBB5129-006E-4AD7-BAD5-8B7CA1D10ED6}
+		{8C6B2B13-58A4-4506-9DAB-1F882A093FE0} = {C9F0AB5D-F4D7-40C8-A353-3305C86D6D4C}
 	EndGlobalSection
 	GlobalSection(ExtensibilityGlobals) = postSolution
 		SolutionGuid = {3448830C-EBDC-426C-85CD-7BBB9651A7FE}

+ 1 - 2
Emby.Server.Implementations/LiveTv/EmbyTV/DirectRecorder.cs → src/Jellyfin.LiveTv/EmbyTV/DirectRecorder.cs

@@ -5,7 +5,6 @@ using System.IO;
 using System.Net.Http;
 using System.Threading;
 using System.Threading.Tasks;
-using Jellyfin.Api.Helpers;
 using MediaBrowser.Common.Net;
 using MediaBrowser.Controller.Library;
 using MediaBrowser.Controller.Streaming;
@@ -13,7 +12,7 @@ using MediaBrowser.Model.Dto;
 using MediaBrowser.Model.IO;
 using Microsoft.Extensions.Logging;
 
-namespace Emby.Server.Implementations.LiveTv.EmbyTV
+namespace Jellyfin.LiveTv.EmbyTV
 {
     public sealed class DirectRecorder : IRecorder
     {

+ 1 - 3
Emby.Server.Implementations/LiveTv/EmbyTV/EmbyTV.cs → src/Jellyfin.LiveTv/EmbyTV/EmbyTV.cs

@@ -14,14 +14,12 @@ using System.Text;
 using System.Threading;
 using System.Threading.Tasks;
 using System.Xml;
-using Emby.Server.Implementations.Library;
 using Jellyfin.Data.Enums;
 using Jellyfin.Data.Events;
 using Jellyfin.Extensions;
 using MediaBrowser.Common.Configuration;
 using MediaBrowser.Common.Extensions;
 using MediaBrowser.Common.Progress;
-using MediaBrowser.Controller;
 using MediaBrowser.Controller.Configuration;
 using MediaBrowser.Controller.Dto;
 using MediaBrowser.Controller.Entities;
@@ -39,7 +37,7 @@ using MediaBrowser.Model.MediaInfo;
 using MediaBrowser.Model.Providers;
 using Microsoft.Extensions.Logging;
 
-namespace Emby.Server.Implementations.LiveTv.EmbyTV
+namespace Jellyfin.LiveTv.EmbyTV
 {
     public sealed class EmbyTV : ILiveTvService, ISupportsDirectStreamProvider, ISupportsNewTimerIds, IDisposable
     {

+ 1 - 1
Emby.Server.Implementations/LiveTv/EmbyTV/EncodedRecorder.cs → src/Jellyfin.LiveTv/EmbyTV/EncodedRecorder.cs

@@ -23,7 +23,7 @@ using MediaBrowser.Model.Dto;
 using MediaBrowser.Model.IO;
 using Microsoft.Extensions.Logging;
 
-namespace Emby.Server.Implementations.LiveTv.EmbyTV
+namespace Jellyfin.LiveTv.EmbyTV
 {
     public class EncodedRecorder : IRecorder
     {

+ 1 - 1
Emby.Server.Implementations/LiveTv/EmbyTV/EntryPoint.cs → src/Jellyfin.LiveTv/EmbyTV/EntryPoint.cs

@@ -3,7 +3,7 @@
 using System.Threading.Tasks;
 using MediaBrowser.Controller.Plugins;
 
-namespace Emby.Server.Implementations.LiveTv.EmbyTV
+namespace Jellyfin.LiveTv.EmbyTV
 {
     public sealed class EntryPoint : IServerEntryPoint
     {

+ 1 - 1
Emby.Server.Implementations/LiveTv/EmbyTV/EpgChannelData.cs → src/Jellyfin.LiveTv/EmbyTV/EpgChannelData.cs

@@ -4,7 +4,7 @@ using System;
 using System.Collections.Generic;
 using MediaBrowser.Controller.LiveTv;
 
-namespace Emby.Server.Implementations.LiveTv.EmbyTV
+namespace Jellyfin.LiveTv.EmbyTV
 {
     internal class EpgChannelData
     {

+ 1 - 1
Emby.Server.Implementations/LiveTv/EmbyTV/IRecorder.cs → src/Jellyfin.LiveTv/EmbyTV/IRecorder.cs

@@ -6,7 +6,7 @@ using System.Threading.Tasks;
 using MediaBrowser.Controller.Library;
 using MediaBrowser.Model.Dto;
 
-namespace Emby.Server.Implementations.LiveTv.EmbyTV
+namespace Jellyfin.LiveTv.EmbyTV
 {
     public interface IRecorder : IDisposable
     {

+ 1 - 1
Emby.Server.Implementations/LiveTv/EmbyTV/ItemDataProvider.cs → src/Jellyfin.LiveTv/EmbyTV/ItemDataProvider.cs

@@ -9,7 +9,7 @@ using System.Text.Json;
 using Jellyfin.Extensions.Json;
 using Microsoft.Extensions.Logging;
 
-namespace Emby.Server.Implementations.LiveTv.EmbyTV
+namespace Jellyfin.LiveTv.EmbyTV
 {
     public class ItemDataProvider<T>
         where T : class

+ 1 - 1
Emby.Server.Implementations/LiveTv/EmbyTV/NfoConfigurationExtensions.cs → src/Jellyfin.LiveTv/EmbyTV/NfoConfigurationExtensions.cs

@@ -1,7 +1,7 @@
 using MediaBrowser.Common.Configuration;
 using MediaBrowser.Model.Configuration;
 
-namespace Emby.Server.Implementations.LiveTv.EmbyTV
+namespace Jellyfin.LiveTv.EmbyTV
 {
     /// <summary>
     /// Class containing extension methods for working with the nfo configuration.

+ 1 - 1
Emby.Server.Implementations/LiveTv/EmbyTV/RecordingHelper.cs → src/Jellyfin.LiveTv/EmbyTV/RecordingHelper.cs

@@ -5,7 +5,7 @@ using System.Globalization;
 using System.Text;
 using MediaBrowser.Controller.LiveTv;
 
-namespace Emby.Server.Implementations.LiveTv.EmbyTV
+namespace Jellyfin.LiveTv.EmbyTV
 {
     internal static class RecordingHelper
     {

+ 1 - 1
Emby.Server.Implementations/LiveTv/EmbyTV/SeriesTimerManager.cs → src/Jellyfin.LiveTv/EmbyTV/SeriesTimerManager.cs

@@ -4,7 +4,7 @@ using System;
 using MediaBrowser.Controller.LiveTv;
 using Microsoft.Extensions.Logging;
 
-namespace Emby.Server.Implementations.LiveTv.EmbyTV
+namespace Jellyfin.LiveTv.EmbyTV
 {
     public class SeriesTimerManager : ItemDataProvider<SeriesTimerInfo>
     {

+ 1 - 1
Emby.Server.Implementations/LiveTv/EmbyTV/TimerManager.cs → src/Jellyfin.LiveTv/EmbyTV/TimerManager.cs

@@ -10,7 +10,7 @@ using MediaBrowser.Controller.LiveTv;
 using MediaBrowser.Model.LiveTv;
 using Microsoft.Extensions.Logging;
 
-namespace Emby.Server.Implementations.LiveTv.EmbyTV
+namespace Jellyfin.LiveTv.EmbyTV
 {
     public class TimerManager : ItemDataProvider<TimerInfo>
     {

+ 2 - 1
Emby.Server.Implementations/Library/ExclusiveLiveStream.cs → src/Jellyfin.LiveTv/ExclusiveLiveStream.cs

@@ -1,5 +1,6 @@
 #nullable disable
 
+#pragma warning disable CA1711
 #pragma warning disable CS1591
 
 using System;
@@ -10,7 +11,7 @@ using System.Threading.Tasks;
 using MediaBrowser.Controller.Library;
 using MediaBrowser.Model.Dto;
 
-namespace Emby.Server.Implementations.Library
+namespace Jellyfin.LiveTv
 {
     public sealed class ExclusiveLiveStream : ILiveStream
     {

+ 22 - 0
src/Jellyfin.LiveTv/Jellyfin.LiveTv.csproj

@@ -0,0 +1,22 @@
+<Project Sdk="Microsoft.NET.Sdk">
+  <PropertyGroup>
+    <TargetFramework>net8.0</TargetFramework>
+    <GenerateDocumentationFile>true</GenerateDocumentationFile>
+  </PropertyGroup>
+
+  <ItemGroup>
+    <AssemblyAttribute Include="System.Runtime.CompilerServices.InternalsVisibleToAttribute">
+      <_Parameter1>Jellyfin.LiveTv.Tests</_Parameter1>
+    </AssemblyAttribute>
+  </ItemGroup>
+
+  <ItemGroup>
+    <PackageReference Include="Jellyfin.XmlTv" />
+  </ItemGroup>
+
+  <ItemGroup>
+    <ProjectReference Include="..\..\MediaBrowser.Model\MediaBrowser.Model.csproj" />
+    <ProjectReference Include="..\..\MediaBrowser.Controller\MediaBrowser.Controller.csproj" />
+    <ProjectReference Include="..\..\MediaBrowser.Common\MediaBrowser.Common.csproj" />
+  </ItemGroup>
+</Project>

+ 4 - 2
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirect.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirect.cs

@@ -16,9 +16,9 @@ using System.Text;
 using System.Text.Json;
 using System.Threading;
 using System.Threading.Tasks;
-using Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos;
 using Jellyfin.Extensions;
 using Jellyfin.Extensions.Json;
+using Jellyfin.LiveTv.Listings.SchedulesDirectDtos;
 using MediaBrowser.Common.Net;
 using MediaBrowser.Controller.Authentication;
 using MediaBrowser.Controller.LiveTv;
@@ -27,7 +27,7 @@ using MediaBrowser.Model.Entities;
 using MediaBrowser.Model.LiveTv;
 using Microsoft.Extensions.Logging;
 
-namespace Emby.Server.Implementations.LiveTv.Listings
+namespace Jellyfin.LiveTv.Listings
 {
     public class SchedulesDirect : IListingsProvider, IDisposable
     {
@@ -613,6 +613,7 @@ namespace Emby.Server.Implementations.LiveTv.Listings
 
             // Response is automatically disposed in the calling function,
             // so dispose manually if not returning.
+#pragma warning disable IDISP016, IDISP017
             response.Dispose();
             if (!enableRetry || (int)response.StatusCode >= 500)
             {
@@ -621,6 +622,7 @@ namespace Emby.Server.Implementations.LiveTv.Listings
                     null,
                     response.StatusCode);
             }
+#pragma warning restore IDISP016, IDISP017
 
             _tokens.Clear();
             options.Headers.TryAddWithoutValidation("token", await GetToken(providerInfo, cancellationToken).ConfigureAwait(false));

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/BroadcasterDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/BroadcasterDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Broadcaster dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/CaptionDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/CaptionDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Caption dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/CastDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/CastDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Cast dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/ChannelDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/ChannelDto.cs

@@ -2,7 +2,7 @@ using System;
 using System.Collections.Generic;
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Channel dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/ContentRatingDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/ContentRatingDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Content rating dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/CrewDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/CrewDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Crew dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/DayDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/DayDto.cs

@@ -2,7 +2,7 @@ using System;
 using System.Collections.Generic;
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Day dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/Description1000Dto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/Description1000Dto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Description 1_000 dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/Description100Dto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/Description100Dto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Description 100 dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/DescriptionsProgramDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/DescriptionsProgramDto.cs

@@ -2,7 +2,7 @@ using System;
 using System.Collections.Generic;
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Descriptions program dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/EventDetailsDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/EventDetailsDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Event details dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/GracenoteDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/GracenoteDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Gracenote dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/HeadendsDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/HeadendsDto.cs

@@ -2,7 +2,7 @@ using System;
 using System.Collections.Generic;
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Headends dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/ImageDataDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/ImageDataDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Image data dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/LineupDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/LineupDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// The lineup dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/LineupsDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/LineupsDto.cs

@@ -2,7 +2,7 @@ using System;
 using System.Collections.Generic;
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Lineups dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/LogoDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/LogoDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Logo dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/MapDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/MapDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Map dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/MetadataDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/MetadataDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Metadata dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/MetadataProgramsDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/MetadataProgramsDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Metadata programs dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/MetadataScheduleDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/MetadataScheduleDto.cs

@@ -1,7 +1,7 @@
 using System;
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Metadata schedule dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/MovieDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/MovieDto.cs

@@ -2,7 +2,7 @@ using System;
 using System.Collections.Generic;
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Movie dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/MultipartDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/MultipartDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Multipart dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/ProgramDetailsDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/ProgramDetailsDto.cs

@@ -2,7 +2,7 @@ using System;
 using System.Collections.Generic;
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Program details dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/ProgramDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/ProgramDto.cs

@@ -2,7 +2,7 @@ using System;
 using System.Collections.Generic;
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Program dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/QualityRatingDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/QualityRatingDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Quality rating dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/RatingDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/RatingDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Rating dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/RecommendationDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/RecommendationDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Recommendation dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/RequestScheduleForChannelDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/RequestScheduleForChannelDto.cs

@@ -2,7 +2,7 @@ using System;
 using System.Collections.Generic;
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Request schedule for channel dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/ShowImagesDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/ShowImagesDto.cs

@@ -2,7 +2,7 @@ using System;
 using System.Collections.Generic;
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Show image dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/StationDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/StationDto.cs

@@ -2,7 +2,7 @@ using System;
 using System.Collections.Generic;
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Station dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/TitleDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/TitleDto.cs

@@ -1,6 +1,6 @@
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// Title dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirectDtos/TokenDto.cs → src/Jellyfin.LiveTv/Listings/SchedulesDirectDtos/TokenDto.cs

@@ -1,7 +1,7 @@
 using System;
 using System.Text.Json.Serialization;
 
-namespace Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos
+namespace Jellyfin.LiveTv.Listings.SchedulesDirectDtos
 {
     /// <summary>
     /// The token dto.

+ 1 - 1
Emby.Server.Implementations/LiveTv/Listings/XmlTvListingsProvider.cs → src/Jellyfin.LiveTv/Listings/XmlTvListingsProvider.cs

@@ -23,7 +23,7 @@ using MediaBrowser.Model.IO;
 using MediaBrowser.Model.LiveTv;
 using Microsoft.Extensions.Logging;
 
-namespace Emby.Server.Implementations.LiveTv.Listings
+namespace Jellyfin.LiveTv.Listings
 {
     public class XmlTvListingsProvider : IListingsProvider
     {

+ 1 - 1
Emby.Server.Implementations/LiveTv/LiveTvConfigurationFactory.cs → src/Jellyfin.LiveTv/LiveTvConfigurationFactory.cs

@@ -2,7 +2,7 @@ using System.Collections.Generic;
 using MediaBrowser.Common.Configuration;
 using MediaBrowser.Model.LiveTv;
 
-namespace Emby.Server.Implementations.LiveTv
+namespace Jellyfin.LiveTv
 {
     /// <summary>
     /// <see cref="IConfigurationFactory" /> implementation for <see cref="LiveTvOptions" />.

+ 1 - 1
Emby.Server.Implementations/LiveTv/LiveTvDtoService.cs → src/Jellyfin.LiveTv/LiveTvDtoService.cs

@@ -20,7 +20,7 @@ using MediaBrowser.Model.Entities;
 using MediaBrowser.Model.LiveTv;
 using Microsoft.Extensions.Logging;
 
-namespace Emby.Server.Implementations.LiveTv
+namespace Jellyfin.LiveTv
 {
     public class LiveTvDtoService
     {

+ 3 - 2
Emby.Server.Implementations/LiveTv/LiveTvManager.cs → src/Jellyfin.LiveTv/LiveTvManager.cs

@@ -9,7 +9,6 @@ using System.Linq;
 using System.Text.Json;
 using System.Threading;
 using System.Threading.Tasks;
-using Emby.Server.Implementations.Library;
 using Jellyfin.Data.Entities;
 using Jellyfin.Data.Enums;
 using Jellyfin.Data.Events;
@@ -34,7 +33,7 @@ using MediaBrowser.Model.Querying;
 using MediaBrowser.Model.Tasks;
 using Microsoft.Extensions.Logging;
 
-namespace Emby.Server.Implementations.LiveTv
+namespace Jellyfin.LiveTv
 {
     /// <summary>
     /// Class LiveTvManager.
@@ -231,7 +230,9 @@ namespace Emby.Server.Implementations.LiveTv
             _logger.LogInformation("Opening channel stream from {0}, external channel Id: {1}", service.Name, channel.ExternalId);
 
             MediaSourceInfo info;
+#pragma warning disable CA1859 // TODO: Analyzer bug?
             ILiveStream liveStream;
+#pragma warning restore CA1859
             if (service is ISupportsDirectStreamProvider supportsManagedStream)
             {
                 liveStream = await supportsManagedStream.GetChannelStreamWithDirectStreamProvider(channel.ExternalId, mediaSourceId, currentLiveStreams, cancellationToken).ConfigureAwait(false);

+ 1 - 1
Emby.Server.Implementations/LiveTv/LiveTvMediaSourceProvider.cs → src/Jellyfin.LiveTv/LiveTvMediaSourceProvider.cs

@@ -16,7 +16,7 @@ using MediaBrowser.Model.Dto;
 using MediaBrowser.Model.MediaInfo;
 using Microsoft.Extensions.Logging;
 
-namespace Emby.Server.Implementations.LiveTv
+namespace Jellyfin.LiveTv
 {
     public class LiveTvMediaSourceProvider : IMediaSourceProvider
     {

+ 1 - 1
Emby.Server.Implementations/LiveTv/RefreshGuideScheduledTask.cs → src/Jellyfin.LiveTv/RefreshGuideScheduledTask.cs

@@ -7,7 +7,7 @@ using MediaBrowser.Controller.LiveTv;
 using MediaBrowser.Model.LiveTv;
 using MediaBrowser.Model.Tasks;
 
-namespace Emby.Server.Implementations.LiveTv
+namespace Jellyfin.LiveTv
 {
     /// <summary>
     /// The "Refresh Guide" scheduled task.

+ 1 - 1
Emby.Server.Implementations/LiveTv/TunerHosts/BaseTunerHost.cs → src/Jellyfin.LiveTv/TunerHosts/BaseTunerHost.cs

@@ -19,7 +19,7 @@ using MediaBrowser.Model.IO;
 using MediaBrowser.Model.LiveTv;
 using Microsoft.Extensions.Logging;
 
-namespace Emby.Server.Implementations.LiveTv.TunerHosts
+namespace Jellyfin.LiveTv.TunerHosts
 {
     public abstract class BaseTunerHost
     {

+ 1 - 1
Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/Channels.cs → src/Jellyfin.LiveTv/TunerHosts/HdHomerun/Channels.cs

@@ -1,6 +1,6 @@
 #nullable disable
 
-namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
+namespace Jellyfin.LiveTv.TunerHosts.HdHomerun
 {
     internal class Channels
     {

+ 1 - 1
Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/DiscoverResponse.cs → src/Jellyfin.LiveTv/TunerHosts/HdHomerun/DiscoverResponse.cs

@@ -2,7 +2,7 @@
 
 using System;
 
-namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
+namespace Jellyfin.LiveTv.TunerHosts.HdHomerun
 {
     internal class DiscoverResponse
     {

+ 1 - 1
Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/HdHomerunChannelCommands.cs → src/Jellyfin.LiveTv/TunerHosts/HdHomerun/HdHomerunChannelCommands.cs

@@ -3,7 +3,7 @@
 using System;
 using System.Collections.Generic;
 
-namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
+namespace Jellyfin.LiveTv.TunerHosts.HdHomerun
 {
     public class HdHomerunChannelCommands : IHdHomerunChannelCommands
     {

+ 4 - 4
Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/HdHomerunHost.cs → src/Jellyfin.LiveTv/TunerHosts/HdHomerun/HdHomerunHost.cs

@@ -30,7 +30,7 @@ using MediaBrowser.Model.MediaInfo;
 using MediaBrowser.Model.Net;
 using Microsoft.Extensions.Logging;
 
-namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
+namespace Jellyfin.LiveTv.TunerHosts.HdHomerun
 {
     public class HdHomerunHost : BaseTunerHost, ITunerHost, IConfigurableTunerHost
     {
@@ -143,7 +143,7 @@ namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
                 if (!throwAllExceptions && ex.StatusCode.HasValue && ex.StatusCode.Value == HttpStatusCode.NotFound)
                 {
                     const string DefaultValue = "HDHR";
-                    var response = new DiscoverResponse
+                    var discoverResponse = new DiscoverResponse
                     {
                         ModelNumber = DefaultValue
                     };
@@ -152,11 +152,11 @@ namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
                         // HDHR4 doesn't have this api
                         lock (_modelCache)
                         {
-                            _modelCache[cacheKey] = response;
+                            _modelCache[cacheKey] = discoverResponse;
                         }
                     }
 
-                    return response;
+                    return discoverResponse;
                 }
 
                 throw;

+ 1 - 1
Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/HdHomerunManager.cs → src/Jellyfin.LiveTv/TunerHosts/HdHomerun/HdHomerunManager.cs

@@ -14,7 +14,7 @@ using System.Threading.Tasks;
 using MediaBrowser.Common;
 using MediaBrowser.Controller.LiveTv;
 
-namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
+namespace Jellyfin.LiveTv.TunerHosts.HdHomerun
 {
     public sealed class HdHomerunManager : IDisposable
     {

+ 2 - 1
Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/HdHomerunUdpStream.cs → src/Jellyfin.LiveTv/TunerHosts/HdHomerun/HdHomerunUdpStream.cs

@@ -1,5 +1,6 @@
 #nullable disable
 
+#pragma warning disable CA1711
 #pragma warning disable CS1591
 
 using System;
@@ -19,7 +20,7 @@ using MediaBrowser.Model.LiveTv;
 using MediaBrowser.Model.MediaInfo;
 using Microsoft.Extensions.Logging;
 
-namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
+namespace Jellyfin.LiveTv.TunerHosts.HdHomerun
 {
     public class HdHomerunUdpStream : LiveStream, IDirectStreamProvider
     {

+ 1 - 1
Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/IHdHomerunChannelCommands.cs → src/Jellyfin.LiveTv/TunerHosts/HdHomerun/IHdHomerunChannelCommands.cs

@@ -2,7 +2,7 @@
 
 using System.Collections.Generic;
 
-namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
+namespace Jellyfin.LiveTv.TunerHosts.HdHomerun
 {
     public interface IHdHomerunChannelCommands
     {

+ 1 - 1
Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/LegacyHdHomerunChannelCommands.cs → src/Jellyfin.LiveTv/TunerHosts/HdHomerun/LegacyHdHomerunChannelCommands.cs

@@ -3,7 +3,7 @@
 using System.Collections.Generic;
 using System.Text.RegularExpressions;
 
-namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
+namespace Jellyfin.LiveTv.TunerHosts.HdHomerun
 {
     public partial class LegacyHdHomerunChannelCommands : IHdHomerunChannelCommands
     {

+ 2 - 1
Emby.Server.Implementations/LiveTv/TunerHosts/LiveStream.cs → src/Jellyfin.LiveTv/TunerHosts/LiveStream.cs

@@ -1,5 +1,6 @@
 #nullable disable
 
+#pragma warning disable CA1711
 #pragma warning disable CS1591
 
 using System;
@@ -14,7 +15,7 @@ using MediaBrowser.Model.IO;
 using MediaBrowser.Model.LiveTv;
 using Microsoft.Extensions.Logging;
 
-namespace Emby.Server.Implementations.LiveTv.TunerHosts
+namespace Jellyfin.LiveTv.TunerHosts
 {
     public class LiveStream : ILiveStream
     {

+ 1 - 1
Emby.Server.Implementations/LiveTv/TunerHosts/M3UTunerHost.cs → src/Jellyfin.LiveTv/TunerHosts/M3UTunerHost.cs

@@ -24,7 +24,7 @@ using MediaBrowser.Model.MediaInfo;
 using Microsoft.Extensions.Logging;
 using Microsoft.Net.Http.Headers;
 
-namespace Emby.Server.Implementations.LiveTv.TunerHosts
+namespace Jellyfin.LiveTv.TunerHosts
 {
     public class M3UTunerHost : BaseTunerHost, ITunerHost, IConfigurableTunerHost
     {

+ 1 - 1
Emby.Server.Implementations/LiveTv/TunerHosts/M3uParser.cs → src/Jellyfin.LiveTv/TunerHosts/M3uParser.cs

@@ -18,7 +18,7 @@ using MediaBrowser.Model.IO;
 using MediaBrowser.Model.LiveTv;
 using Microsoft.Extensions.Logging;
 
-namespace Emby.Server.Implementations.LiveTv.TunerHosts
+namespace Jellyfin.LiveTv.TunerHosts
 {
     public partial class M3uParser
     {

+ 2 - 1
Emby.Server.Implementations/LiveTv/TunerHosts/SharedHttpStream.cs → src/Jellyfin.LiveTv/TunerHosts/SharedHttpStream.cs

@@ -1,3 +1,4 @@
+#pragma warning disable CA1711
 #pragma warning disable CS1591
 
 using System;
@@ -16,7 +17,7 @@ using MediaBrowser.Model.LiveTv;
 using MediaBrowser.Model.MediaInfo;
 using Microsoft.Extensions.Logging;
 
-namespace Emby.Server.Implementations.LiveTv.TunerHosts
+namespace Jellyfin.LiveTv.TunerHosts
 {
     public class SharedHttpStream : LiveStream, IDirectStreamProvider
     {

+ 1 - 1
tests/Jellyfin.LiveTv.Tests/HdHomerunHostTests.cs

@@ -6,7 +6,7 @@ using System.Threading;
 using System.Threading.Tasks;
 using AutoFixture;
 using AutoFixture.AutoMoq;
-using Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun;
+using Jellyfin.LiveTv.TunerHosts.HdHomerun;
 using MediaBrowser.Model.LiveTv;
 using Moq;
 using Moq.Protected;

+ 1 - 1
tests/Jellyfin.LiveTv.Tests/HdHomerunManagerTests.cs

@@ -1,6 +1,6 @@
 using System;
 using System.Text;
-using Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun;
+using Jellyfin.LiveTv.TunerHosts.HdHomerun;
 using Xunit;
 
 namespace Jellyfin.LiveTv.Tests

+ 1 - 1
tests/Jellyfin.LiveTv.Tests/Jellyfin.LiveTv.Tests.csproj

@@ -24,6 +24,6 @@
   </ItemGroup>
   
   <ItemGroup>
-    <ProjectReference Include="..\..\Emby.Server.Implementations\Emby.Server.Implementations.csproj" />
+    <ProjectReference Include="..\..\src\Jellyfin.LiveTv\Jellyfin.LiveTv.csproj" />
   </ItemGroup>
 </Project>

+ 1 - 1
tests/Jellyfin.LiveTv.Tests/Listings/XmlTvListingsProviderTests.cs

@@ -6,7 +6,7 @@ using System.Threading;
 using System.Threading.Tasks;
 using AutoFixture;
 using AutoFixture.AutoMoq;
-using Emby.Server.Implementations.LiveTv.Listings;
+using Jellyfin.LiveTv.Listings;
 using MediaBrowser.Model.LiveTv;
 using Moq;
 using Moq.Protected;

+ 1 - 1
tests/Jellyfin.LiveTv.Tests/RecordingHelperTests.cs

@@ -1,5 +1,5 @@
 using System;
-using Emby.Server.Implementations.LiveTv.EmbyTV;
+using Jellyfin.LiveTv.EmbyTV;
 using MediaBrowser.Controller.LiveTv;
 using Xunit;
 

+ 1 - 1
tests/Jellyfin.LiveTv.Tests/SchedulesDirect/SchedulesDirectDeserializeTests.cs

@@ -2,8 +2,8 @@ using System;
 using System.Collections.Generic;
 using System.IO;
 using System.Text.Json;
-using Emby.Server.Implementations.LiveTv.Listings.SchedulesDirectDtos;
 using Jellyfin.Extensions.Json;
+using Jellyfin.LiveTv.Listings.SchedulesDirectDtos;
 using Xunit;
 
 namespace Jellyfin.LiveTv.Tests.SchedulesDirect