mirror of
				https://github.com/jellyfin/jellyfin.git
				synced 2025-10-26 16:22:44 -04:00 
			
		
		
		
	Update StyleCop
This commit is contained in:
		
							parent
							
								
									2e7d173188
								
							
						
					
					
						commit
						cbfa355e31
					
				| @ -6,7 +6,7 @@ | |||||||
|     <CodeAnalysisRuleSet>$(MSBuildThisFileDirectory)/jellyfin.ruleset</CodeAnalysisRuleSet> |     <CodeAnalysisRuleSet>$(MSBuildThisFileDirectory)/jellyfin.ruleset</CodeAnalysisRuleSet> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
| 
 | 
 | ||||||
|   <PropertyGroup Condition=" '$(Configuration)' == 'Release' "> |   <PropertyGroup> | ||||||
|     <TreatWarningsAsErrors>true</TreatWarningsAsErrors> |     <TreatWarningsAsErrors>true</TreatWarningsAsErrors> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -22,10 +22,14 @@ | |||||||
|     <GenerateDocumentationFile>true</GenerateDocumentationFile> |     <GenerateDocumentationFile>true</GenerateDocumentationFile> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
| 
 | 
 | ||||||
|  |   <PropertyGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|  |     <TreatWarningsAsErrors>false</TreatWarningsAsErrors> | ||||||
|  |   </PropertyGroup> | ||||||
|  | 
 | ||||||
|   <!-- Code Analyzers--> |   <!-- Code Analyzers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -11,6 +11,10 @@ | |||||||
|     <GenerateDocumentationFile>true</GenerateDocumentationFile> |     <GenerateDocumentationFile>true</GenerateDocumentationFile> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
| 
 | 
 | ||||||
|  |   <PropertyGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|  |     <TreatWarningsAsErrors>false</TreatWarningsAsErrors> | ||||||
|  |   </PropertyGroup> | ||||||
|  | 
 | ||||||
|   <ItemGroup> |   <ItemGroup> | ||||||
|     <ProjectReference Include="..\MediaBrowser.Model\MediaBrowser.Model.csproj" /> |     <ProjectReference Include="..\MediaBrowser.Model\MediaBrowser.Model.csproj" /> | ||||||
|     <ProjectReference Include="..\MediaBrowser.Controller\MediaBrowser.Controller.csproj" /> |     <ProjectReference Include="..\MediaBrowser.Controller\MediaBrowser.Controller.csproj" /> | ||||||
| @ -24,7 +28,7 @@ | |||||||
|   <!-- Code analysers--> |   <!-- Code analysers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -101,8 +101,7 @@ namespace Emby.Drawing | |||||||
|         public async Task ProcessImage(ImageProcessingOptions options, Stream toStream) |         public async Task ProcessImage(ImageProcessingOptions options, Stream toStream) | ||||||
|         { |         { | ||||||
|             var file = await ProcessImage(options).ConfigureAwait(false); |             var file = await ProcessImage(options).ConfigureAwait(false); | ||||||
| 
 |             using (var fileStream = AsyncFile.OpenRead(file.path)) | ||||||
|             using (var fileStream = AsyncFile.OpenRead(file.Item1)) |  | ||||||
|             { |             { | ||||||
|                 await fileStream.CopyToAsync(toStream).ConfigureAwait(false); |                 await fileStream.CopyToAsync(toStream).ConfigureAwait(false); | ||||||
|             } |             } | ||||||
|  | |||||||
| @ -33,7 +33,6 @@ namespace Emby.Naming.AudioBook | |||||||
|         /// <returns>Returns IEnumerable of <see cref="AudioBookInfo"/>.</returns> |         /// <returns>Returns IEnumerable of <see cref="AudioBookInfo"/>.</returns> | ||||||
|         public IEnumerable<AudioBookInfo> Resolve(IEnumerable<FileSystemMetadata> files) |         public IEnumerable<AudioBookInfo> Resolve(IEnumerable<FileSystemMetadata> files) | ||||||
|         { |         { | ||||||
| 
 |  | ||||||
|             // File with empty fullname will be sorted out here. |             // File with empty fullname will be sorted out here. | ||||||
|             var audiobookFileInfos = files |             var audiobookFileInfos = files | ||||||
|                 .Select(i => _audioBookResolver.Resolve(i.FullName)) |                 .Select(i => _audioBookResolver.Resolve(i.FullName)) | ||||||
|  | |||||||
| @ -15,6 +15,10 @@ | |||||||
|     <SymbolPackageFormat>snupkg</SymbolPackageFormat> |     <SymbolPackageFormat>snupkg</SymbolPackageFormat> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
| 
 | 
 | ||||||
|  |   <PropertyGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|  |     <TreatWarningsAsErrors>false</TreatWarningsAsErrors> | ||||||
|  |   </PropertyGroup> | ||||||
|  | 
 | ||||||
|   <PropertyGroup Condition=" '$(Stability)'=='Unstable'"> |   <PropertyGroup Condition=" '$(Stability)'=='Unstable'"> | ||||||
|     <!-- Include all symbols in the main nupkg until Azure Artifact Feed starts supporting ingesting NuGet symbol packages. --> |     <!-- Include all symbols in the main nupkg until Azure Artifact Feed starts supporting ingesting NuGet symbol packages. --> | ||||||
|     <AllowedOutputExtensionsInPackageBuildOutputFolder>$(AllowedOutputExtensionsInPackageBuildOutputFolder);.pdb</AllowedOutputExtensionsInPackageBuildOutputFolder> |     <AllowedOutputExtensionsInPackageBuildOutputFolder>$(AllowedOutputExtensionsInPackageBuildOutputFolder);.pdb</AllowedOutputExtensionsInPackageBuildOutputFolder> | ||||||
| @ -44,7 +48,7 @@ | |||||||
|   <!-- Code Analyzers--> |   <!-- Code Analyzers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -24,7 +24,7 @@ | |||||||
|   <!-- Code analyzers--> |   <!-- Code analyzers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -26,7 +26,7 @@ | |||||||
| 
 | 
 | ||||||
|   <!-- Code Analyzers--> |   <!-- Code Analyzers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
|  | |||||||
| @ -174,7 +174,8 @@ namespace Emby.Server.Implementations.Data | |||||||
|                     } |                     } | ||||||
| 
 | 
 | ||||||
|                     return false; |                     return false; | ||||||
|             }, ReadTransactionMode); |                 }, | ||||||
|  |                 ReadTransactionMode); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         protected List<string> GetColumnNames(IDatabaseConnection connection, string table) |         protected List<string> GetColumnNames(IDatabaseConnection connection, string table) | ||||||
|  | |||||||
| @ -600,7 +600,8 @@ namespace Emby.Server.Implementations.Data | |||||||
|                         AddColumn(db, "MediaStreams", "ColorPrimaries", "TEXT", existingColumnNames); |                         AddColumn(db, "MediaStreams", "ColorPrimaries", "TEXT", existingColumnNames); | ||||||
|                         AddColumn(db, "MediaStreams", "ColorSpace", "TEXT", existingColumnNames); |                         AddColumn(db, "MediaStreams", "ColorSpace", "TEXT", existingColumnNames); | ||||||
|                         AddColumn(db, "MediaStreams", "ColorTransfer", "TEXT", existingColumnNames); |                         AddColumn(db, "MediaStreams", "ColorTransfer", "TEXT", existingColumnNames); | ||||||
|                 }, TransactionMode); |                     }, | ||||||
|  |                     TransactionMode); | ||||||
| 
 | 
 | ||||||
|                 connection.RunQueries(postQueries); |                 connection.RunQueries(postQueries); | ||||||
|             } |             } | ||||||
| @ -645,7 +646,8 @@ namespace Emby.Server.Implementations.Data | |||||||
| 
 | 
 | ||||||
|                             saveImagesStatement.MoveNext(); |                             saveImagesStatement.MoveNext(); | ||||||
|                         } |                         } | ||||||
|                 }, TransactionMode); |                     }, | ||||||
|  |                     TransactionMode); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -689,7 +691,8 @@ namespace Emby.Server.Implementations.Data | |||||||
|                     db => |                     db => | ||||||
|                     { |                     { | ||||||
|                         SaveItemsInTranscation(db, tuples); |                         SaveItemsInTranscation(db, tuples); | ||||||
|                 }, TransactionMode); |                     }, | ||||||
|  |                     TransactionMode); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -2140,7 +2143,8 @@ namespace Emby.Server.Implementations.Data | |||||||
|                         db.Execute("delete from " + ChaptersTableName + " where ItemId=@ItemId", idBlob); |                         db.Execute("delete from " + ChaptersTableName + " where ItemId=@ItemId", idBlob); | ||||||
| 
 | 
 | ||||||
|                         InsertChapters(idBlob, chapters, db); |                         InsertChapters(idBlob, chapters, db); | ||||||
|                 }, TransactionMode); |                     }, | ||||||
|  |                     TransactionMode); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -3006,7 +3010,8 @@ namespace Emby.Server.Implementations.Data | |||||||
| 
 | 
 | ||||||
|                             LogQueryTime("GetItems.TotalRecordCount", totalRecordCountQuery, now); |                             LogQueryTime("GetItems.TotalRecordCount", totalRecordCountQuery, now); | ||||||
|                         } |                         } | ||||||
|                 }, ReadTransactionMode); |                     }, | ||||||
|  |                     ReadTransactionMode); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             result.Items = list; |             result.Items = list; | ||||||
| @ -3407,7 +3412,8 @@ namespace Emby.Server.Implementations.Data | |||||||
|                                 result.TotalRecordCount = statement.ExecuteQuery().SelectScalarInt().First(); |                                 result.TotalRecordCount = statement.ExecuteQuery().SelectScalarInt().First(); | ||||||
|                             } |                             } | ||||||
|                         } |                         } | ||||||
|                 }, ReadTransactionMode); |                     }, | ||||||
|  |                     ReadTransactionMode); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             LogQueryTime("GetItemIds", commandText, now); |             LogQueryTime("GetItemIds", commandText, now); | ||||||
| @ -4957,7 +4963,8 @@ where AncestorIdText not null and ItemValues.Value not null and ItemValues.Type | |||||||
|                     db => |                     db => | ||||||
|                     { |                     { | ||||||
|                         connection.ExecuteAll(sql); |                         connection.ExecuteAll(sql); | ||||||
|                 }, TransactionMode); |                     }, | ||||||
|  |                     TransactionMode); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -5009,7 +5016,8 @@ where AncestorIdText not null and ItemValues.Value not null and ItemValues.Type | |||||||
| 
 | 
 | ||||||
|                         // Delete the item |                         // Delete the item | ||||||
|                         ExecuteWithSingleParam(db, "delete from TypedBaseItems where guid=@Id", idBlob); |                         ExecuteWithSingleParam(db, "delete from TypedBaseItems where guid=@Id", idBlob); | ||||||
|                 }, TransactionMode); |                     }, | ||||||
|  |                     TransactionMode); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -5816,7 +5824,8 @@ AND Type = @InternalPersonType)"); | |||||||
|                         db.Execute("delete from People where ItemId=@ItemId", itemIdBlob); |                         db.Execute("delete from People where ItemId=@ItemId", itemIdBlob); | ||||||
| 
 | 
 | ||||||
|                         InsertPeople(itemIdBlob, people, db); |                         InsertPeople(itemIdBlob, people, db); | ||||||
|                 }, TransactionMode); |                     }, | ||||||
|  |                     TransactionMode); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -5974,7 +5983,8 @@ AND Type = @InternalPersonType)"); | |||||||
|                     db.Execute("delete from mediastreams where ItemId=@ItemId", itemIdBlob); |                     db.Execute("delete from mediastreams where ItemId=@ItemId", itemIdBlob); | ||||||
| 
 | 
 | ||||||
|                     InsertMediaStreams(itemIdBlob, streams, db); |                     InsertMediaStreams(itemIdBlob, streams, db); | ||||||
|                 }, TransactionMode); |                 }, | ||||||
|  |                 TransactionMode); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -6308,7 +6318,8 @@ AND Type = @InternalPersonType)"); | |||||||
|                     db.Execute("delete from mediaattachments where ItemId=@ItemId", itemIdBlob); |                     db.Execute("delete from mediaattachments where ItemId=@ItemId", itemIdBlob); | ||||||
| 
 | 
 | ||||||
|                     InsertMediaAttachments(itemIdBlob, attachments, db, cancellationToken); |                     InsertMediaAttachments(itemIdBlob, attachments, db, cancellationToken); | ||||||
|                 }, TransactionMode); |                 }, | ||||||
|  |                 TransactionMode); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -84,7 +84,8 @@ namespace Emby.Server.Implementations.Data | |||||||
|                                 db.ExecuteAll("INSERT INTO UserDatas (key, userId, rating, played, playCount, isFavorite, playbackPositionTicks, lastPlayedDate, AudioStreamIndex, SubtitleStreamIndex) SELECT key, InternalUserId, rating, played, playCount, isFavorite, playbackPositionTicks, lastPlayedDate, AudioStreamIndex, SubtitleStreamIndex from userdata where InternalUserId not null"); |                                 db.ExecuteAll("INSERT INTO UserDatas (key, userId, rating, played, playCount, isFavorite, playbackPositionTicks, lastPlayedDate, AudioStreamIndex, SubtitleStreamIndex) SELECT key, InternalUserId, rating, played, playCount, isFavorite, playbackPositionTicks, lastPlayedDate, AudioStreamIndex, SubtitleStreamIndex from userdata where InternalUserId not null"); | ||||||
|                             } |                             } | ||||||
|                         } |                         } | ||||||
|                 }, TransactionMode); |                     }, | ||||||
|  |                     TransactionMode); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -186,7 +187,8 @@ namespace Emby.Server.Implementations.Data | |||||||
|                     db => |                     db => | ||||||
|                     { |                     { | ||||||
|                         SaveUserData(db, internalUserId, key, userData); |                         SaveUserData(db, internalUserId, key, userData); | ||||||
|                 }, TransactionMode); |                     }, | ||||||
|  |                     TransactionMode); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -258,7 +260,8 @@ namespace Emby.Server.Implementations.Data | |||||||
|                         { |                         { | ||||||
|                             SaveUserData(db, internalUserId, userItemData.Key, userItemData); |                             SaveUserData(db, internalUserId, userItemData.Key, userItemData); | ||||||
|                         } |                         } | ||||||
|                 }, TransactionMode); |                     }, | ||||||
|  |                     TransactionMode); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -49,10 +49,14 @@ | |||||||
|     <NoWarn>AD0001</NoWarn> |     <NoWarn>AD0001</NoWarn> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
| 
 | 
 | ||||||
|  |   <PropertyGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|  |     <TreatWarningsAsErrors>false</TreatWarningsAsErrors> | ||||||
|  |   </PropertyGroup> | ||||||
|  | 
 | ||||||
|   <!-- Code Analyzers--> |   <!-- Code Analyzers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -236,7 +236,8 @@ namespace Emby.Server.Implementations.HttpServer | |||||||
|                 { |                 { | ||||||
|                     MessageId = Guid.NewGuid(), |                     MessageId = Guid.NewGuid(), | ||||||
|                     MessageType = SessionMessageType.KeepAlive |                     MessageType = SessionMessageType.KeepAlive | ||||||
|                 }, CancellationToken.None); |                 }, | ||||||
|  |                 CancellationToken.None); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /// <inheritdoc /> |         /// <inheritdoc /> | ||||||
|  | |||||||
| @ -34,7 +34,6 @@ namespace Emby.Server.Implementations.Library.Resolvers | |||||||
|             "default" |             "default" | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|         public PhotoResolver(IImageProcessor imageProcessor, NamingOptions namingOptions) |         public PhotoResolver(IImageProcessor imageProcessor, NamingOptions namingOptions) | ||||||
|         { |         { | ||||||
|             _imageProcessor = imageProcessor; |             _imageProcessor = imageProcessor; | ||||||
|  | |||||||
| @ -1,16 +1,16 @@ | |||||||
| using System; | using System; | ||||||
|  | using System.Collections.Generic; | ||||||
| using System.Linq; | using System.Linq; | ||||||
| using System.Threading; | using System.Threading; | ||||||
| using System.Threading.Tasks; | using System.Threading.Tasks; | ||||||
| using System.Collections.Generic; | using Jellyfin.Data.Enums; | ||||||
| using MediaBrowser.Controller.Collections; | using MediaBrowser.Controller.Collections; | ||||||
| using MediaBrowser.Controller.Entities; | using MediaBrowser.Controller.Entities; | ||||||
| using MediaBrowser.Controller.Entities.Movies; | using MediaBrowser.Controller.Entities.Movies; | ||||||
| using MediaBrowser.Controller.Library; | using MediaBrowser.Controller.Library; | ||||||
| using MediaBrowser.Model.Querying; |  | ||||||
| using Jellyfin.Data.Enums; |  | ||||||
| using Microsoft.Extensions.Logging; |  | ||||||
| using MediaBrowser.Model.Entities; | using MediaBrowser.Model.Entities; | ||||||
|  | using MediaBrowser.Model.Querying; | ||||||
|  | using Microsoft.Extensions.Logging; | ||||||
| 
 | 
 | ||||||
| namespace Emby.Server.Implementations.Library.Validators | namespace Emby.Server.Implementations.Library.Validators | ||||||
| { | { | ||||||
|  | |||||||
| @ -122,7 +122,8 @@ namespace Emby.Server.Implementations.TV | |||||||
|                         Limit = limit, |                         Limit = limit, | ||||||
|                         DtoOptions = new DtoOptions { Fields = new[] { ItemFields.SeriesPresentationUniqueKey }, EnableImages = false }, |                         DtoOptions = new DtoOptions { Fields = new[] { ItemFields.SeriesPresentationUniqueKey }, EnableImages = false }, | ||||||
|                         GroupBySeriesPresentationUniqueKey = true |                         GroupBySeriesPresentationUniqueKey = true | ||||||
|                     }, parentsFolders.ToList()) |                     }, | ||||||
|  |                     parentsFolders.ToList()) | ||||||
|                 .Cast<Episode>() |                 .Cast<Episode>() | ||||||
|                 .Where(episode => !string.IsNullOrEmpty(episode.SeriesPresentationUniqueKey)) |                 .Where(episode => !string.IsNullOrEmpty(episode.SeriesPresentationUniqueKey)) | ||||||
|                 .Select(GetUniqueSeriesKey); |                 .Select(GetUniqueSeriesKey); | ||||||
|  | |||||||
| @ -264,7 +264,8 @@ namespace Jellyfin.Api.Controllers | |||||||
|                     ReplaceAllMetadata = true, |                     ReplaceAllMetadata = true, | ||||||
|                     ReplaceAllImages = replaceAllImages, |                     ReplaceAllImages = replaceAllImages, | ||||||
|                     SearchResult = searchResult |                     SearchResult = searchResult | ||||||
|                 }, CancellationToken.None).ConfigureAwait(false); |                 }, | ||||||
|  |                 CancellationToken.None).ConfigureAwait(false); | ||||||
| 
 | 
 | ||||||
|             return NoContent(); |             return NoContent(); | ||||||
|         } |         } | ||||||
|  | |||||||
| @ -296,7 +296,8 @@ namespace Jellyfin.Api.Controllers | |||||||
|                     Fields = fields, |                     Fields = fields, | ||||||
|                     ImageTypeLimit = imageTypeLimit, |                     ImageTypeLimit = imageTypeLimit, | ||||||
|                     EnableImages = enableImages |                     EnableImages = enableImages | ||||||
|             }, dtoOptions); |                 }, | ||||||
|  |                 dtoOptions); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
| @ -495,8 +496,8 @@ namespace Jellyfin.Api.Controllers | |||||||
|                     SeriesTimerId = seriesTimerId, |                     SeriesTimerId = seriesTimerId, | ||||||
|                     IsActive = isActive, |                     IsActive = isActive, | ||||||
|                     IsScheduled = isScheduled |                     IsScheduled = isScheduled | ||||||
|                     }, CancellationToken.None) |                 }, | ||||||
|                 .ConfigureAwait(false); |                 CancellationToken.None).ConfigureAwait(false); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
| @ -867,7 +868,8 @@ namespace Jellyfin.Api.Controllers | |||||||
|                 { |                 { | ||||||
|                     SortOrder = sortOrder ?? SortOrder.Ascending, |                     SortOrder = sortOrder ?? SortOrder.Ascending, | ||||||
|                     SortBy = sortBy |                     SortBy = sortBy | ||||||
|                 }, CancellationToken.None).ConfigureAwait(false); |                 }, | ||||||
|  |                 CancellationToken.None).ConfigureAwait(false); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|  | |||||||
| @ -80,7 +80,8 @@ namespace Jellyfin.Api.Controllers | |||||||
|                         IncludeAllLanguages = includeAllLanguages, |                         IncludeAllLanguages = includeAllLanguages, | ||||||
|                         IncludeDisabledProviders = true, |                         IncludeDisabledProviders = true, | ||||||
|                         ImageType = type |                         ImageType = type | ||||||
|                     }, CancellationToken.None) |                     }, | ||||||
|  |                     CancellationToken.None) | ||||||
|                 .ConfigureAwait(false); |                 .ConfigureAwait(false); | ||||||
| 
 | 
 | ||||||
|             var imageArray = images.ToArray(); |             var imageArray = images.ToArray(); | ||||||
|  | |||||||
| @ -301,7 +301,8 @@ namespace Jellyfin.Api.Controllers | |||||||
|                     Limit = limit, |                     Limit = limit, | ||||||
|                     ParentId = parentId ?? Guid.Empty, |                     ParentId = parentId ?? Guid.Empty, | ||||||
|                     UserId = userId, |                     UserId = userId, | ||||||
|                 }, dtoOptions); |                 }, | ||||||
|  |                 dtoOptions); | ||||||
| 
 | 
 | ||||||
|             var dtos = list.Select(i => |             var dtos = list.Select(i => | ||||||
|             { |             { | ||||||
|  | |||||||
| @ -218,7 +218,8 @@ namespace Jellyfin.Api.Helpers | |||||||
|             return KillTranscodingJobs( |             return KillTranscodingJobs( | ||||||
|                 j => string.IsNullOrWhiteSpace(playSessionId) |                 j => string.IsNullOrWhiteSpace(playSessionId) | ||||||
|                     ? string.Equals(deviceId, j.DeviceId, StringComparison.OrdinalIgnoreCase) |                     ? string.Equals(deviceId, j.DeviceId, StringComparison.OrdinalIgnoreCase) | ||||||
|                     : string.Equals(playSessionId, j.PlaySessionId, StringComparison.OrdinalIgnoreCase), deleteFiles); |                     : string.Equals(playSessionId, j.PlaySessionId, StringComparison.OrdinalIgnoreCase), | ||||||
|  |                 deleteFiles); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|  | |||||||
| @ -12,6 +12,10 @@ | |||||||
|     <NoWarn>AD0001</NoWarn> |     <NoWarn>AD0001</NoWarn> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
| 
 | 
 | ||||||
|  |   <PropertyGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|  |     <TreatWarningsAsErrors>false</TreatWarningsAsErrors> | ||||||
|  |   </PropertyGroup> | ||||||
|  | 
 | ||||||
|   <ItemGroup> |   <ItemGroup> | ||||||
|     <PackageReference Include="Microsoft.AspNetCore.Authorization" Version="6.0.1" /> |     <PackageReference Include="Microsoft.AspNetCore.Authorization" Version="6.0.1" /> | ||||||
|     <PackageReference Include="Microsoft.Extensions.Http" Version="6.0.0" /> |     <PackageReference Include="Microsoft.Extensions.Http" Version="6.0.0" /> | ||||||
| @ -27,7 +31,7 @@ | |||||||
|   <!-- Code Analyzers--> |   <!-- Code Analyzers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -134,7 +134,7 @@ | |||||||
|         PlaylistsFolder, |         PlaylistsFolder, | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Item is program |         /// Item is program. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|         Program, |         Program, | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -31,7 +31,7 @@ namespace Jellyfin.Data.Enums | |||||||
|         Book = 4, |         Book = 4, | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// A live TV channel |         /// A live TV channel. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|         LiveTvChannel = 5, |         LiveTvChannel = 5, | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -30,7 +30,7 @@ | |||||||
|   <!-- Code analysers--> |   <!-- Code analysers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -31,7 +31,7 @@ | |||||||
|   <!-- Code analysers--> |   <!-- Code analysers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -12,7 +12,7 @@ | |||||||
|   <!-- Code Analyzers--> |   <!-- Code Analyzers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -6,10 +6,14 @@ | |||||||
|     <GenerateDocumentationFile>true</GenerateDocumentationFile> |     <GenerateDocumentationFile>true</GenerateDocumentationFile> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
| 
 | 
 | ||||||
|  |   <PropertyGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|  |     <TreatWarningsAsErrors>false</TreatWarningsAsErrors> | ||||||
|  |   </PropertyGroup> | ||||||
|  | 
 | ||||||
|   <!-- Code analysers--> |   <!-- Code analysers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -14,6 +14,10 @@ | |||||||
|     <GenerateDocumentationFile>true</GenerateDocumentationFile> |     <GenerateDocumentationFile>true</GenerateDocumentationFile> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
| 
 | 
 | ||||||
|  |   <PropertyGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|  |     <TreatWarningsAsErrors>false</TreatWarningsAsErrors> | ||||||
|  |   </PropertyGroup> | ||||||
|  | 
 | ||||||
|   <ItemGroup> |   <ItemGroup> | ||||||
|     <Compile Include="..\SharedVersion.cs" /> |     <Compile Include="..\SharedVersion.cs" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| @ -25,7 +29,7 @@ | |||||||
|   <!-- Code Analyzers--> |   <!-- Code Analyzers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -38,6 +38,10 @@ | |||||||
|     <SymbolPackageFormat>snupkg</SymbolPackageFormat> |     <SymbolPackageFormat>snupkg</SymbolPackageFormat> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
| 
 | 
 | ||||||
|  |   <PropertyGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|  |     <TreatWarningsAsErrors>false</TreatWarningsAsErrors> | ||||||
|  |   </PropertyGroup> | ||||||
|  | 
 | ||||||
|   <PropertyGroup Condition=" '$(Stability)'=='Unstable'"> |   <PropertyGroup Condition=" '$(Stability)'=='Unstable'"> | ||||||
|     <!-- Include all symbols in the main nupkg until Azure Artifact Feed starts supporting ingesting NuGet symbol packages. --> |     <!-- Include all symbols in the main nupkg until Azure Artifact Feed starts supporting ingesting NuGet symbol packages. --> | ||||||
|     <AllowedOutputExtensionsInPackageBuildOutputFolder>$(AllowedOutputExtensionsInPackageBuildOutputFolder);.pdb</AllowedOutputExtensionsInPackageBuildOutputFolder> |     <AllowedOutputExtensionsInPackageBuildOutputFolder>$(AllowedOutputExtensionsInPackageBuildOutputFolder);.pdb</AllowedOutputExtensionsInPackageBuildOutputFolder> | ||||||
| @ -46,7 +50,7 @@ | |||||||
|   <!-- Code analyzers--> |   <!-- Code analyzers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -2592,9 +2592,9 @@ namespace MediaBrowser.Controller.Entities | |||||||
|                 .Select(i => i.OfficialRating) |                 .Select(i => i.OfficialRating) | ||||||
|                 .Where(i => !string.IsNullOrEmpty(i)) |                 .Where(i => !string.IsNullOrEmpty(i)) | ||||||
|                 .Distinct(StringComparer.OrdinalIgnoreCase) |                 .Distinct(StringComparer.OrdinalIgnoreCase) | ||||||
|                 .Select(i => (i, LocalizationManager.GetRatingLevel(i))) |                 .Select(rating => (rating, LocalizationManager.GetRatingLevel(rating))) | ||||||
|                 .OrderBy(i => i.Item2 ?? 1000) |                 .OrderBy(i => i.Item2 ?? 1000) | ||||||
|                 .Select(i => i.Item1); |                 .Select(i => i.rating); | ||||||
| 
 | 
 | ||||||
|             OfficialRating = ratings.FirstOrDefault() ?? currentOfficialRating; |             OfficialRating = ratings.FirstOrDefault() ?? currentOfficialRating; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -51,7 +51,8 @@ namespace MediaBrowser.Controller.Entities | |||||||
|                     { |                     { | ||||||
|                         Path = file, |                         Path = file, | ||||||
|                         Type = imageType |                         Type = imageType | ||||||
|                 }, 0); |                     }, | ||||||
|  |                     0); | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
|  | |||||||
| @ -13,6 +13,10 @@ | |||||||
|     <PackageLicenseExpression>GPL-3.0-only</PackageLicenseExpression> |     <PackageLicenseExpression>GPL-3.0-only</PackageLicenseExpression> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
| 
 | 
 | ||||||
|  |   <PropertyGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|  |     <TreatWarningsAsErrors>false</TreatWarningsAsErrors> | ||||||
|  |   </PropertyGroup> | ||||||
|  | 
 | ||||||
|   <ItemGroup> |   <ItemGroup> | ||||||
|     <PackageReference Include="Diacritics" Version="3.3.10" /> |     <PackageReference Include="Diacritics" Version="3.3.10" /> | ||||||
|     <PackageReference Include="Microsoft.Extensions.Configuration.Abstractions" Version="6.0.0" /> |     <PackageReference Include="Microsoft.Extensions.Configuration.Abstractions" Version="6.0.0" /> | ||||||
| @ -49,7 +53,7 @@ | |||||||
|   <!-- Code Analyzers--> |   <!-- Code Analyzers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -23,7 +23,7 @@ | |||||||
|   <!-- Code Analyzers--> |   <!-- Code Analyzers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -11,6 +11,10 @@ | |||||||
|     <GenerateDocumentationFile>true</GenerateDocumentationFile> |     <GenerateDocumentationFile>true</GenerateDocumentationFile> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
| 
 | 
 | ||||||
|  |   <PropertyGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|  |     <TreatWarningsAsErrors>false</TreatWarningsAsErrors> | ||||||
|  |   </PropertyGroup> | ||||||
|  | 
 | ||||||
|   <ItemGroup> |   <ItemGroup> | ||||||
|     <Compile Include="..\SharedVersion.cs" /> |     <Compile Include="..\SharedVersion.cs" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| @ -32,7 +36,7 @@ | |||||||
|   <!-- Code Analyzers--> |   <!-- Code Analyzers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -679,8 +679,8 @@ namespace MediaBrowser.Model.Dlna | |||||||
|             // TODO: This doesn't account for situations where the device is able to handle the media's bitrate, but the connection isn't fast enough |             // TODO: This doesn't account for situations where the device is able to handle the media's bitrate, but the connection isn't fast enough | ||||||
|             var directPlayEligibilityResult = IsEligibleForDirectPlay(item, GetBitrateForDirectPlayCheck(item, options, true) ?? 0, subtitleStream, audioStream, options, PlayMethod.DirectPlay); |             var directPlayEligibilityResult = IsEligibleForDirectPlay(item, GetBitrateForDirectPlayCheck(item, options, true) ?? 0, subtitleStream, audioStream, options, PlayMethod.DirectPlay); | ||||||
|             var directStreamEligibilityResult = IsEligibleForDirectPlay(item, options.GetMaxBitrate(false) ?? 0, subtitleStream, audioStream, options, PlayMethod.DirectStream); |             var directStreamEligibilityResult = IsEligibleForDirectPlay(item, options.GetMaxBitrate(false) ?? 0, subtitleStream, audioStream, options, PlayMethod.DirectStream); | ||||||
|             bool isEligibleForDirectPlay = options.EnableDirectPlay && (options.ForceDirectPlay || directPlayEligibilityResult.Item1); |             bool isEligibleForDirectPlay = options.EnableDirectPlay && (options.ForceDirectPlay || directPlayEligibilityResult.directPlay); | ||||||
|             bool isEligibleForDirectStream = options.EnableDirectStream && (options.ForceDirectStream || directStreamEligibilityResult.Item1); |             bool isEligibleForDirectStream = options.EnableDirectStream && (options.ForceDirectStream || directStreamEligibilityResult.directPlay); | ||||||
| 
 | 
 | ||||||
|             _logger.LogDebug( |             _logger.LogDebug( | ||||||
|                 "Profile: {0}, Path: {1}, isEligibleForDirectPlay: {2}, isEligibleForDirectStream: {3}", |                 "Profile: {0}, Path: {1}, isEligibleForDirectPlay: {2}, isEligibleForDirectStream: {3}", | ||||||
| @ -695,7 +695,7 @@ namespace MediaBrowser.Model.Dlna | |||||||
|             { |             { | ||||||
|                 // See if it can be direct played |                 // See if it can be direct played | ||||||
|                 var directPlayInfo = GetVideoDirectPlayProfile(options, item, videoStream, audioStream, isEligibleForDirectStream); |                 var directPlayInfo = GetVideoDirectPlayProfile(options, item, videoStream, audioStream, isEligibleForDirectStream); | ||||||
|                 var directPlay = directPlayInfo.Item1; |                 var directPlay = directPlayInfo.playMethod; | ||||||
| 
 | 
 | ||||||
|                 if (directPlay != null) |                 if (directPlay != null) | ||||||
|                 { |                 { | ||||||
| @ -713,17 +713,17 @@ namespace MediaBrowser.Model.Dlna | |||||||
|                     return playlistItem; |                     return playlistItem; | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 transcodeReasons.AddRange(directPlayInfo.Item2); |                 transcodeReasons.AddRange(directPlayInfo.transcodeReasons); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (directPlayEligibilityResult.Item2.HasValue) |             if (directPlayEligibilityResult.reason.HasValue) | ||||||
|             { |             { | ||||||
|                 transcodeReasons.Add(directPlayEligibilityResult.Item2.Value); |                 transcodeReasons.Add(directPlayEligibilityResult.reason.Value); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (directStreamEligibilityResult.Item2.HasValue) |             if (directStreamEligibilityResult.reason.HasValue) | ||||||
|             { |             { | ||||||
|                 transcodeReasons.Add(directStreamEligibilityResult.Item2.Value); |                 transcodeReasons.Add(directStreamEligibilityResult.reason.Value); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             // Can't direct play, find the transcoding profile |             // Can't direct play, find the transcoding profile | ||||||
| @ -1000,7 +1000,7 @@ namespace MediaBrowser.Model.Dlna | |||||||
|             return 7168000; |             return 7168000; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private (PlayMethod?, List<TranscodeReason>) GetVideoDirectPlayProfile( |         private (PlayMethod? playMethod, List<TranscodeReason> transcodeReasons) GetVideoDirectPlayProfile( | ||||||
|             VideoOptions options, |             VideoOptions options, | ||||||
|             MediaSourceInfo mediaSource, |             MediaSourceInfo mediaSource, | ||||||
|             MediaStream videoStream, |             MediaStream videoStream, | ||||||
|  | |||||||
| @ -23,6 +23,10 @@ | |||||||
|     <SymbolPackageFormat>snupkg</SymbolPackageFormat> |     <SymbolPackageFormat>snupkg</SymbolPackageFormat> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
| 
 | 
 | ||||||
|  |   <PropertyGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|  |     <TreatWarningsAsErrors>false</TreatWarningsAsErrors> | ||||||
|  |   </PropertyGroup> | ||||||
|  | 
 | ||||||
|   <PropertyGroup Condition=" '$(Stability)'=='Unstable'"> |   <PropertyGroup Condition=" '$(Stability)'=='Unstable'"> | ||||||
|     <!-- Include all symbols in the main nupkg until Azure Artifact Feed starts supporting ingesting NuGet symbol packages. --> |     <!-- Include all symbols in the main nupkg until Azure Artifact Feed starts supporting ingesting NuGet symbol packages. --> | ||||||
|     <AllowedOutputExtensionsInPackageBuildOutputFolder>$(AllowedOutputExtensionsInPackageBuildOutputFolder);.pdb</AllowedOutputExtensionsInPackageBuildOutputFolder> |     <AllowedOutputExtensionsInPackageBuildOutputFolder>$(AllowedOutputExtensionsInPackageBuildOutputFolder);.pdb</AllowedOutputExtensionsInPackageBuildOutputFolder> | ||||||
| @ -46,7 +50,7 @@ | |||||||
|   <!-- Code Analyzers--> |   <!-- Code Analyzers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
|   <ItemGroup> |   <ItemGroup> | ||||||
|  | |||||||
| @ -29,7 +29,7 @@ namespace MediaBrowser.Model.Plugins | |||||||
|         NotSupported = -2, |         NotSupported = -2, | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// This plugin caused an error when instantiated. (Either DI loop, or exception) |         /// This plugin caused an error when instantiated (either DI loop, or exception). | ||||||
|         /// </summary> |         /// </summary> | ||||||
|         Malfunctioned = -3, |         Malfunctioned = -3, | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -6,42 +6,42 @@ | |||||||
|     public enum HardwareEncodingType |     public enum HardwareEncodingType | ||||||
|     { |     { | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// AMD AMF |         /// AMD AMF. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|         AMF = 0, |         AMF = 0, | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Intel Quick Sync Video |         /// Intel Quick Sync Video. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|         QSV = 1, |         QSV = 1, | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// NVIDIA NVENC |         /// NVIDIA NVENC. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|         NVENC = 2, |         NVENC = 2, | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// OpenMax OMX |         /// OpenMax OMX. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|         OMX = 3, |         OMX = 3, | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Exynos V4L2 MFC |         /// Exynos V4L2 MFC. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|         V4L2M2M = 4, |         V4L2M2M = 4, | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// MediaCodec Android |         /// MediaCodec Android. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|         MediaCodec = 5, |         MediaCodec = 5, | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Video Acceleration API (VAAPI) |         /// Video Acceleration API (VAAPI). | ||||||
|         /// </summary> |         /// </summary> | ||||||
|         VAAPI = 6, |         VAAPI = 6, | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Video ToolBox |         /// Video ToolBox. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|         VideoToolBox = 7 |         VideoToolBox = 7 | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -32,10 +32,14 @@ | |||||||
|     <CodeAnalysisRuleSet>../jellyfin.ruleset</CodeAnalysisRuleSet> |     <CodeAnalysisRuleSet>../jellyfin.ruleset</CodeAnalysisRuleSet> | ||||||
|   </PropertyGroup> |   </PropertyGroup> | ||||||
| 
 | 
 | ||||||
|  |   <PropertyGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|  |     <TreatWarningsAsErrors>false</TreatWarningsAsErrors> | ||||||
|  |   </PropertyGroup> | ||||||
|  | 
 | ||||||
|   <!-- Code Analyzers--> |   <!-- Code Analyzers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -27,7 +27,7 @@ namespace MediaBrowser.Providers.Studios | |||||||
|         private readonly IServerConfigurationManager _config; |         private readonly IServerConfigurationManager _config; | ||||||
|         private readonly IHttpClientFactory _httpClientFactory; |         private readonly IHttpClientFactory _httpClientFactory; | ||||||
|         private readonly IFileSystem _fileSystem; |         private readonly IFileSystem _fileSystem; | ||||||
|         private readonly String repositoryUrl; |         private readonly string repositoryUrl; | ||||||
| 
 | 
 | ||||||
|         public StudiosImageProvider(IServerConfigurationManager config, IHttpClientFactory httpClientFactory, IFileSystem fileSystem) |         public StudiosImageProvider(IServerConfigurationManager config, IHttpClientFactory httpClientFactory, IFileSystem fileSystem) | ||||||
|         { |         { | ||||||
|  | |||||||
| @ -23,7 +23,7 @@ | |||||||
|   <!-- Code Analyzers--> |   <!-- Code Analyzers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,6 +1,21 @@ | |||||||
| <?xml version="1.0" encoding="utf-8"?> | <?xml version="1.0" encoding="utf-8"?> | ||||||
| <RuleSet Name="Rules for Jellyfin.Server" Description="Code analysis rules for Jellyfin.Server.csproj" ToolsVersion="14.0"> | <RuleSet Name="Rules for Jellyfin.Server" Description="Code analysis rules for Jellyfin.Server.csproj" ToolsVersion="14.0"> | ||||||
|   <Rules AnalyzerId="StyleCop.Analyzers" RuleNamespace="StyleCop.Analyzers"> |   <Rules AnalyzerId="StyleCop.Analyzers" RuleNamespace="StyleCop.Analyzers"> | ||||||
|  |     <!-- error on SA1000: The keyword 'new' should be followed by a space --> | ||||||
|  |     <Rule Id="SA1000" Action="Error" /> | ||||||
|  |     <!-- error on SA1001: Commas should not be preceded by whitespace --> | ||||||
|  |     <Rule Id="SA1001" Action="Error" /> | ||||||
|  |     <!-- error on SA1117: The parameters should all be placed on the same line or each parameter should be placed on its own line --> | ||||||
|  |     <Rule Id="SA1117" Action="Error" /> | ||||||
|  |     <!-- error on SA1142: Refer to tuple fields by name --> | ||||||
|  |     <Rule Id="SA1142" Action="Error" /> | ||||||
|  |     <!-- error on SA1210: Using directives should be ordered alphabetically by the namespaces --> | ||||||
|  |     <Rule Id="SA1210" Action="Error" /> | ||||||
|  |     <!-- error on SA1518: File is required to end with a single newline character --> | ||||||
|  |     <Rule Id="SA1518" Action="Error" /> | ||||||
|  |     <!-- error on SA1629: Documentation text should end with a period --> | ||||||
|  |     <Rule Id="SA1629" Action="Error" /> | ||||||
|  | 
 | ||||||
|     <!-- disable warning SA1009: Closing parenthesis should be followed by a space. --> |     <!-- disable warning SA1009: Closing parenthesis should be followed by a space. --> | ||||||
|     <Rule Id="SA1009" Action="None" /> |     <Rule Id="SA1009" Action="None" /> | ||||||
|     <!-- disable warning SA1011: Closing square bracket should be followed by a space. --> |     <!-- disable warning SA1011: Closing square bracket should be followed by a space. --> | ||||||
|  | |||||||
| @ -30,7 +30,7 @@ | |||||||
|   <!-- Code Analyzers--> |   <!-- Code Analyzers--> | ||||||
|   <ItemGroup> |   <ItemGroup> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -27,7 +27,7 @@ | |||||||
|   <!-- Code Analyzers --> |   <!-- Code Analyzers --> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -22,7 +22,7 @@ | |||||||
|   <!-- Code Analyzers --> |   <!-- Code Analyzers --> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -22,7 +22,7 @@ | |||||||
|   <!-- Code Analyzers --> |   <!-- Code Analyzers --> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -17,7 +17,7 @@ | |||||||
|   <!-- Code Analyzers --> |   <!-- Code Analyzers --> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -23,7 +23,7 @@ | |||||||
|   <!-- Code Analyzers --> |   <!-- Code Analyzers --> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -31,7 +31,7 @@ | |||||||
|   <!-- Code Analyzers --> |   <!-- Code Analyzers --> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -17,7 +17,7 @@ | |||||||
|   <!-- Code Analyzers --> |   <!-- Code Analyzers --> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -25,7 +25,7 @@ | |||||||
|   <!-- Code Analyzers--> |   <!-- Code Analyzers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -23,7 +23,7 @@ | |||||||
|   <!-- Code Analyzers--> |   <!-- Code Analyzers--> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -29,7 +29,7 @@ | |||||||
|   <!-- Code Analyzers --> |   <!-- Code Analyzers --> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -32,7 +32,7 @@ | |||||||
|   <!-- Code Analyzers --> |   <!-- Code Analyzers --> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,8 +1,8 @@ | |||||||
| using System; | using System; | ||||||
| using System.Net; | using System.Net; | ||||||
| using System.Net.Http; | using System.Net.Http; | ||||||
| using System.Net.Http.Json; |  | ||||||
| using System.Net.Http.Headers; | using System.Net.Http.Headers; | ||||||
|  | using System.Net.Http.Json; | ||||||
| using System.Text.Json; | using System.Text.Json; | ||||||
| using System.Threading.Tasks; | using System.Threading.Tasks; | ||||||
| using Jellyfin.Api.Models.StartupDtos; | using Jellyfin.Api.Models.StartupDtos; | ||||||
|  | |||||||
| @ -29,7 +29,7 @@ | |||||||
|   <!-- Code Analyzers --> |   <!-- Code Analyzers --> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -26,7 +26,8 @@ namespace Jellyfin.Server.Integration.Tests | |||||||
|                     { |                     { | ||||||
|                         Scheme = "ws", |                         Scheme = "ws", | ||||||
|                         Path = "websocket" |                         Path = "websocket" | ||||||
|                     }.Uri, CancellationToken.None)); |                     }.Uri, | ||||||
|  |                     CancellationToken.None)); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -22,7 +22,7 @@ | |||||||
|   <!-- Code Analyzers --> |   <!-- Code Analyzers --> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -23,7 +23,7 @@ | |||||||
|   <!-- Code Analyzers --> |   <!-- Code Analyzers --> | ||||||
|   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> |   <ItemGroup Condition=" '$(Configuration)' == 'Debug' "> | ||||||
|     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> |     <PackageReference Include="SerilogAnalyzer" Version="0.15.0" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="StyleCop.Analyzers" Version="1.1.118" PrivateAssets="All" /> |     <PackageReference Include="StyleCop.Analyzers" Version="1.2.0-beta.376" PrivateAssets="All" /> | ||||||
|     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> |     <PackageReference Include="SmartAnalyzers.MultithreadingAnalyzer" Version="1.1.31" PrivateAssets="All" /> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user