mirror of
				https://github.com/jellyfin/jellyfin.git
				synced 2025-10-25 07:49:17 -04:00 
			
		
		
		
	add fixes for dng images
This commit is contained in:
		
							parent
							
								
									2d29d903be
								
							
						
					
					
						commit
						31b01cbb56
					
				| @ -1141,17 +1141,17 @@ namespace Emby.Dlna.Didl | |||||||
|             int? width = null; |             int? width = null; | ||||||
|             int? height = null; |             int? height = null; | ||||||
| 
 | 
 | ||||||
|             try |             //try | ||||||
|             { |             //{ | ||||||
|                 var size = _imageProcessor.GetImageSize(imageInfo); |             //    var size = _imageProcessor.GetImageSize(imageInfo); | ||||||
| 
 | 
 | ||||||
|                 width = Convert.ToInt32(size.Width); |             //    width = Convert.ToInt32(size.Width); | ||||||
|                 height = Convert.ToInt32(size.Height); |             //    height = Convert.ToInt32(size.Height); | ||||||
|             } |             //} | ||||||
|             catch |             //catch | ||||||
|             { |             //{ | ||||||
| 
 | 
 | ||||||
|             } |             //} | ||||||
| 
 | 
 | ||||||
|             var inputFormat = (Path.GetExtension(imageInfo.Path) ?? string.Empty) |             var inputFormat = (Path.GetExtension(imageInfo.Path) ?? string.Empty) | ||||||
|                 .TrimStart('.') |                 .TrimStart('.') | ||||||
|  | |||||||
| @ -148,7 +148,6 @@ namespace Emby.Drawing.ImageMagick | |||||||
|                     } |                     } | ||||||
| 
 | 
 | ||||||
|                     var originalImageSize = new ImageSize(originalImage.CurrentImage.Width, originalImage.CurrentImage.Height); |                     var originalImageSize = new ImageSize(originalImage.CurrentImage.Width, originalImage.CurrentImage.Height); | ||||||
|                     ImageHelper.SaveImageSize(inputPath, dateModified, originalImageSize); |  | ||||||
| 
 | 
 | ||||||
|                     if (!options.CropWhiteSpace && options.HasDefaultOptions(inputPath, originalImageSize)) |                     if (!options.CropWhiteSpace && options.HasDefaultOptions(inputPath, originalImageSize)) | ||||||
|                     { |                     { | ||||||
| @ -182,7 +181,6 @@ namespace Emby.Drawing.ImageMagick | |||||||
|                 using (var originalImage = new MagickWand(inputPath)) |                 using (var originalImage = new MagickWand(inputPath)) | ||||||
|                 { |                 { | ||||||
|                     var originalImageSize = new ImageSize(originalImage.CurrentImage.Width, originalImage.CurrentImage.Height); |                     var originalImageSize = new ImageSize(originalImage.CurrentImage.Width, originalImage.CurrentImage.Height); | ||||||
|                     ImageHelper.SaveImageSize(inputPath, dateModified, originalImageSize); |  | ||||||
| 
 | 
 | ||||||
|                     var newImageSize = ImageHelper.GetNewImageSize(options, originalImageSize); |                     var newImageSize = ImageHelper.GetNewImageSize(options, originalImageSize); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -40,7 +40,9 @@ namespace Emby.Drawing.Skia | |||||||
|                     "jpeg", |                     "jpeg", | ||||||
|                     "jpg", |                     "jpg", | ||||||
|                     "png", |                     "png", | ||||||
|  | 
 | ||||||
|                     "dng", |                     "dng", | ||||||
|  | 
 | ||||||
|                     "webp", |                     "webp", | ||||||
|                     "gif", |                     "gif", | ||||||
|                     "bmp", |                     "bmp", | ||||||
| @ -459,7 +461,6 @@ namespace Emby.Drawing.Skia | |||||||
|                 //_logger.Info("Color type {0}", bitmap.Info.ColorType); |                 //_logger.Info("Color type {0}", bitmap.Info.ColorType); | ||||||
| 
 | 
 | ||||||
|                 var originalImageSize = new ImageSize(bitmap.Width, bitmap.Height); |                 var originalImageSize = new ImageSize(bitmap.Width, bitmap.Height); | ||||||
|                 ImageHelper.SaveImageSize(inputPath, dateModified, originalImageSize); |  | ||||||
| 
 | 
 | ||||||
|                 if (!options.CropWhiteSpace && options.HasDefaultOptions(inputPath, originalImageSize) && !autoOrient) |                 if (!options.CropWhiteSpace && options.HasDefaultOptions(inputPath, originalImageSize) && !autoOrient) | ||||||
|                 { |                 { | ||||||
|  | |||||||
| @ -35,11 +35,6 @@ namespace Emby.Drawing | |||||||
|         /// </summary> |         /// </summary> | ||||||
|         protected readonly CultureInfo UsCulture = new CultureInfo("en-US"); |         protected readonly CultureInfo UsCulture = new CultureInfo("en-US"); | ||||||
| 
 | 
 | ||||||
|         /// <summary> |  | ||||||
|         /// The _cached imaged sizes |  | ||||||
|         /// </summary> |  | ||||||
|         private readonly ConcurrentDictionary<Guid, ImageSize> _cachedImagedSizes; |  | ||||||
| 
 |  | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Gets the list of currently registered image processors |         /// Gets the list of currently registered image processors | ||||||
|         /// Image processors are specialized metadata providers that run after the normal ones |         /// Image processors are specialized metadata providers that run after the normal ones | ||||||
| @ -75,34 +70,7 @@ namespace Emby.Drawing | |||||||
|             _appPaths = appPaths; |             _appPaths = appPaths; | ||||||
| 
 | 
 | ||||||
|             ImageEnhancers = new IImageEnhancer[] { }; |             ImageEnhancers = new IImageEnhancer[] { }; | ||||||
|             _saveImageSizeTimer = timerFactory.Create(SaveImageSizeCallback, null, Timeout.Infinite, Timeout.Infinite); |  | ||||||
|             ImageHelper.ImageProcessor = this; |             ImageHelper.ImageProcessor = this; | ||||||
| 
 |  | ||||||
|             Dictionary<Guid, ImageSize> sizeDictionary; |  | ||||||
| 
 |  | ||||||
|             try |  | ||||||
|             { |  | ||||||
|                 sizeDictionary = jsonSerializer.DeserializeFromFile<Dictionary<Guid, ImageSize>>(ImageSizeFile) ?? |  | ||||||
|                     new Dictionary<Guid, ImageSize>(); |  | ||||||
|             } |  | ||||||
|             catch (FileNotFoundException) |  | ||||||
|             { |  | ||||||
|                 // No biggie |  | ||||||
|                 sizeDictionary = new Dictionary<Guid, ImageSize>(); |  | ||||||
|             } |  | ||||||
|             catch (IOException) |  | ||||||
|             { |  | ||||||
|                 // No biggie |  | ||||||
|                 sizeDictionary = new Dictionary<Guid, ImageSize>(); |  | ||||||
|             } |  | ||||||
|             catch (Exception ex) |  | ||||||
|             { |  | ||||||
|                 logger.ErrorException("Error parsing image size cache file", ex); |  | ||||||
| 
 |  | ||||||
|                 sizeDictionary = new Dictionary<Guid, ImageSize>(); |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             _cachedImagedSizes = new ConcurrentDictionary<Guid, ImageSize>(sizeDictionary); |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public IImageEncoder ImageEncoder |         public IImageEncoder ImageEncoder | ||||||
| @ -133,7 +101,6 @@ namespace Emby.Drawing | |||||||
|                     "aiff", |                     "aiff", | ||||||
|                     "cr2", |                     "cr2", | ||||||
|                     "crw", |                     "crw", | ||||||
|                     "dng",  |  | ||||||
| 
 | 
 | ||||||
|                     // Remove until supported |                     // Remove until supported | ||||||
|                     //"nef",  |                     //"nef",  | ||||||
| @ -275,15 +242,15 @@ namespace Emby.Drawing | |||||||
|                 return new Tuple<string, string, DateTime>(originalImagePath, MimeTypes.GetMimeType(originalImagePath), dateModified); |                 return new Tuple<string, string, DateTime>(originalImagePath, MimeTypes.GetMimeType(originalImagePath), dateModified); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             ImageSize? originalImageSize = GetSavedImageSize(originalImagePath, dateModified); |             //ImageSize? originalImageSize = GetSavedImageSize(originalImagePath, dateModified); | ||||||
|             if (originalImageSize.HasValue && options.HasDefaultOptions(originalImagePath, originalImageSize.Value) && !autoOrient) |             //if (originalImageSize.HasValue && options.HasDefaultOptions(originalImagePath, originalImageSize.Value) && !autoOrient) | ||||||
|             { |             //{ | ||||||
|                 // Just spit out the original file if all the options are default |             //    // Just spit out the original file if all the options are default | ||||||
|                 _logger.Info("Returning original image {0}", originalImagePath); |             //    _logger.Info("Returning original image {0}", originalImagePath); | ||||||
|                 return new Tuple<string, string, DateTime>(originalImagePath, MimeTypes.GetMimeType(originalImagePath), dateModified); |             //    return new Tuple<string, string, DateTime>(originalImagePath, MimeTypes.GetMimeType(originalImagePath), dateModified); | ||||||
|             } |             //} | ||||||
| 
 | 
 | ||||||
|             var newSize = ImageHelper.GetNewImageSize(options, originalImageSize); |             var newSize = ImageHelper.GetNewImageSize(options, null); | ||||||
|             var quality = options.Quality; |             var quality = options.Quality; | ||||||
| 
 | 
 | ||||||
|             var outputFormat = GetOutputFormat(options.SupportedOutputFormats, requiresTransparency); |             var outputFormat = GetOutputFormat(options.SupportedOutputFormats, requiresTransparency); | ||||||
| @ -477,98 +444,30 @@ namespace Emby.Drawing | |||||||
| 
 | 
 | ||||||
|         public ImageSize GetImageSize(ItemImageInfo info, bool allowSlowMethods) |         public ImageSize GetImageSize(ItemImageInfo info, bool allowSlowMethods) | ||||||
|         { |         { | ||||||
|             return GetImageSize(info.Path, info.DateModified, allowSlowMethods); |             return GetImageSize(info.Path, allowSlowMethods); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public ImageSize GetImageSize(ItemImageInfo info) |         public ImageSize GetImageSize(ItemImageInfo info) | ||||||
|         { |         { | ||||||
|             return GetImageSize(info.Path, info.DateModified, false); |             return GetImageSize(info.Path, false); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public ImageSize GetImageSize(string path) |         public ImageSize GetImageSize(string path) | ||||||
|         { |         { | ||||||
|             return GetImageSize(path, _fileSystem.GetLastWriteTimeUtc(path), false); |             return GetImageSize(path, false); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Gets the size of the image. |         /// Gets the size of the image. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|         /// <param name="path">The path.</param> |         private ImageSize GetImageSize(string path, bool allowSlowMethod) | ||||||
|         /// <param name="imageDateModified">The image date modified.</param> |  | ||||||
|         /// <param name="allowSlowMethod">if set to <c>true</c> [allow slow method].</param> |  | ||||||
|         /// <returns>ImageSize.</returns> |  | ||||||
|         /// <exception cref="System.ArgumentNullException">path</exception> |  | ||||||
|         private ImageSize GetImageSize(string path, DateTime imageDateModified, bool allowSlowMethod) |  | ||||||
|         { |         { | ||||||
|             if (string.IsNullOrEmpty(path)) |             if (string.IsNullOrEmpty(path)) | ||||||
|             { |             { | ||||||
|                 throw new ArgumentNullException("path"); |                 throw new ArgumentNullException("path"); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             ImageSize size; |             return GetImageSizeInternal(path, allowSlowMethod); | ||||||
| 
 |  | ||||||
|             var cacheHash = GetImageSizeKey(path, imageDateModified); |  | ||||||
| 
 |  | ||||||
|             if (!_cachedImagedSizes.TryGetValue(cacheHash, out size)) |  | ||||||
|             { |  | ||||||
|                 size = GetImageSizeInternal(path, allowSlowMethod); |  | ||||||
| 
 |  | ||||||
|                 SaveImageSize(size, cacheHash, false); |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             return size; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         public void SaveImageSize(string path, DateTime imageDateModified, ImageSize size) |  | ||||||
|         { |  | ||||||
|             var cacheHash = GetImageSizeKey(path, imageDateModified); |  | ||||||
|             SaveImageSize(size, cacheHash, true); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         private void SaveImageSize(ImageSize size, Guid cacheHash, bool checkExists) |  | ||||||
|         { |  | ||||||
|             if (size.Width <= 0 || size.Height <= 0) |  | ||||||
|             { |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             if (checkExists && _cachedImagedSizes.ContainsKey(cacheHash)) |  | ||||||
|             { |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             if (checkExists) |  | ||||||
|             { |  | ||||||
|                 if (_cachedImagedSizes.TryAdd(cacheHash, size)) |  | ||||||
|                 { |  | ||||||
|                     StartSaveImageSizeTimer(); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             else |  | ||||||
|             { |  | ||||||
|                 StartSaveImageSizeTimer(); |  | ||||||
|                 _cachedImagedSizes.AddOrUpdate(cacheHash, size, (keyName, oldValue) => size); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         private Guid GetImageSizeKey(string path, DateTime imageDateModified) |  | ||||||
|         { |  | ||||||
|             var name = path + "datemodified=" + imageDateModified.Ticks; |  | ||||||
|             return name.GetMD5(); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         public ImageSize? GetSavedImageSize(string path, DateTime imageDateModified) |  | ||||||
|         { |  | ||||||
|             ImageSize size; |  | ||||||
| 
 |  | ||||||
|             var cacheHash = GetImageSizeKey(path, imageDateModified); |  | ||||||
| 
 |  | ||||||
|             if (_cachedImagedSizes.TryGetValue(cacheHash, out size)) |  | ||||||
|             { |  | ||||||
|                 return size; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             return null; |  | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
| @ -619,39 +518,6 @@ namespace Emby.Drawing | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         private readonly ITimer _saveImageSizeTimer; |  | ||||||
|         private const int SaveImageSizeTimeout = 5000; |  | ||||||
|         private readonly object _saveImageSizeLock = new object(); |  | ||||||
|         private void StartSaveImageSizeTimer() |  | ||||||
|         { |  | ||||||
|             _saveImageSizeTimer.Change(SaveImageSizeTimeout, Timeout.Infinite); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         private void SaveImageSizeCallback(object state) |  | ||||||
|         { |  | ||||||
|             lock (_saveImageSizeLock) |  | ||||||
|             { |  | ||||||
|                 try |  | ||||||
|                 { |  | ||||||
|                     var path = ImageSizeFile; |  | ||||||
|                     _fileSystem.CreateDirectory(_fileSystem.GetDirectoryName(path)); |  | ||||||
|                     _jsonSerializer.SerializeToFile(_cachedImagedSizes, path); |  | ||||||
|                 } |  | ||||||
|                 catch (Exception ex) |  | ||||||
|                 { |  | ||||||
|                     _logger.ErrorException("Error saving image size file", ex); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         private string ImageSizeFile |  | ||||||
|         { |  | ||||||
|             get |  | ||||||
|             { |  | ||||||
|                 return Path.Combine(_appPaths.DataPath, "imagesizes.json"); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Gets the image cache tag. |         /// Gets the image cache tag. | ||||||
|         /// </summary> |         /// </summary> | ||||||
| @ -1016,7 +882,6 @@ namespace Emby.Drawing | |||||||
|                 disposable.Dispose(); |                 disposable.Dispose(); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             _saveImageSizeTimer.Dispose(); |  | ||||||
|             GC.SuppressFinalize(this); |             GC.SuppressFinalize(this); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -3,6 +3,7 @@ using System.IO; | |||||||
| using System.Linq; | using System.Linq; | ||||||
| using System.Threading; | using System.Threading; | ||||||
| using System.Threading.Tasks; | using System.Threading.Tasks; | ||||||
|  | using MediaBrowser.Controller.Drawing; | ||||||
| using MediaBrowser.Controller.Entities; | using MediaBrowser.Controller.Entities; | ||||||
| using MediaBrowser.Controller.Library; | using MediaBrowser.Controller.Library; | ||||||
| using MediaBrowser.Controller.Providers; | using MediaBrowser.Controller.Providers; | ||||||
| @ -20,19 +21,25 @@ namespace Emby.Photos | |||||||
|     { |     { | ||||||
|         private readonly ILogger _logger; |         private readonly ILogger _logger; | ||||||
|         private readonly IFileSystem _fileSystem; |         private readonly IFileSystem _fileSystem; | ||||||
|  |         private IImageProcessor _imageProcessor; | ||||||
| 
 | 
 | ||||||
|         public PhotoProvider(ILogger logger, IFileSystem fileSystem) |         public PhotoProvider(ILogger logger, IFileSystem fileSystem, IImageProcessor imageProcessor) | ||||||
|         { |         { | ||||||
|             _logger = logger; |             _logger = logger; | ||||||
|             _fileSystem = fileSystem; |             _fileSystem = fileSystem; | ||||||
|  |             _imageProcessor = imageProcessor; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         // These are causing taglib to hang | ||||||
|  |         private string[] _excludeExtensions = new string[] { ".dng" }; | ||||||
|  | 
 | ||||||
|         public Task<ItemUpdateType> FetchAsync(Photo item, MetadataRefreshOptions options, CancellationToken cancellationToken) |         public Task<ItemUpdateType> FetchAsync(Photo item, MetadataRefreshOptions options, CancellationToken cancellationToken) | ||||||
|         { |         { | ||||||
|             item.SetImagePath(ImageType.Primary, item.Path); |             item.SetImagePath(ImageType.Primary, item.Path); | ||||||
| 
 | 
 | ||||||
|             // Examples: https://github.com/mono/taglib-sharp/blob/a5f6949a53d09ce63ee7495580d6802921a21f14/tests/fixtures/TagLib.Tests.Images/NullOrientationTest.cs |             // Examples: https://github.com/mono/taglib-sharp/blob/a5f6949a53d09ce63ee7495580d6802921a21f14/tests/fixtures/TagLib.Tests.Images/NullOrientationTest.cs | ||||||
| 
 |             if (!_excludeExtensions.Contains(Path.GetExtension(item.Path) ?? string.Empty, StringComparer.OrdinalIgnoreCase)) | ||||||
|  |             { | ||||||
|                 try |                 try | ||||||
|                 { |                 { | ||||||
|                     using (var fileStream = _fileSystem.OpenRead(item.Path)) |                     using (var fileStream = _fileSystem.OpenRead(item.Path)) | ||||||
| @ -79,6 +86,8 @@ namespace Emby.Photos | |||||||
|                                 } |                                 } | ||||||
|                             } |                             } | ||||||
| 
 | 
 | ||||||
|  |                             if (image != null) | ||||||
|  |                             { | ||||||
|                                 item.CameraMake = image.ImageTag.Make; |                                 item.CameraMake = image.ImageTag.Make; | ||||||
|                                 item.CameraModel = image.ImageTag.Model; |                                 item.CameraModel = image.ImageTag.Model; | ||||||
| 
 | 
 | ||||||
| @ -145,10 +154,20 @@ namespace Emby.Photos | |||||||
|                             } |                             } | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|  |                 } | ||||||
|                 catch (Exception e) |                 catch (Exception e) | ||||||
|                 { |                 { | ||||||
|                     _logger.ErrorException("Image Provider - Error reading image tag for {0}", e, item.Path); |                     _logger.ErrorException("Image Provider - Error reading image tag for {0}", e, item.Path); | ||||||
|                 } |                 } | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (!item.Width.HasValue || !item.Height.HasValue) | ||||||
|  |             { | ||||||
|  |                 var size = _imageProcessor.GetImageSize(item.Path); | ||||||
|  | 
 | ||||||
|  |                 item.Width = Convert.ToInt32(size.Width); | ||||||
|  |                 item.Height = Convert.ToInt32(size.Height); | ||||||
|  |             } | ||||||
| 
 | 
 | ||||||
|             const ItemUpdateType result = ItemUpdateType.ImageUpdate | ItemUpdateType.MetadataImport; |             const ItemUpdateType result = ItemUpdateType.ImageUpdate | ItemUpdateType.MetadataImport; | ||||||
|             return Task.FromResult(result); |             return Task.FromResult(result); | ||||||
|  | |||||||
| @ -1642,6 +1642,8 @@ namespace Emby.Server.Implementations.Dto | |||||||
|                     return null; |                     return null; | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|  |                 _logger.Info("Getting image size for item type {0}", item.GetType().Name); | ||||||
|  | 
 | ||||||
|                 try |                 try | ||||||
|                 { |                 { | ||||||
|                     size = _imageProcessor.GetImageSize(imageInfo); |                     size = _imageProcessor.GetImageSize(imageInfo); | ||||||
| @ -1673,22 +1675,6 @@ namespace Emby.Server.Implementations.Dto | |||||||
|                 return null; |                 return null; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             var photo = item as Photo; |  | ||||||
|             if (photo != null && photo.Orientation.HasValue) |  | ||||||
|             { |  | ||||||
|                 switch (photo.Orientation.Value) |  | ||||||
|                 { |  | ||||||
|                     case ImageOrientation.LeftBottom: |  | ||||||
|                     case ImageOrientation.LeftTop: |  | ||||||
|                     case ImageOrientation.RightBottom: |  | ||||||
|                     case ImageOrientation.RightTop: |  | ||||||
|                         var temp = height; |  | ||||||
|                         height = width; |  | ||||||
|                         width = temp; |  | ||||||
|                         break; |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             return width / height; |             return width / height; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -360,7 +360,7 @@ namespace Emby.Server.Implementations.HttpServer | |||||||
|                 if (IsNotModified(requestContext, cacheKey, lastDateModified, cacheDuration)) |                 if (IsNotModified(requestContext, cacheKey, lastDateModified, cacheDuration)) | ||||||
|                 { |                 { | ||||||
|                     AddAgeHeader(responseHeaders, lastDateModified); |                     AddAgeHeader(responseHeaders, lastDateModified); | ||||||
|                     AddExpiresHeader(responseHeaders, cacheKeyString, cacheDuration, noCache); |                     AddExpiresHeader(responseHeaders, cacheKeyString, cacheDuration); | ||||||
| 
 | 
 | ||||||
|                     var result = new HttpResult(new byte[] { }, contentType ?? "text/html", HttpStatusCode.NotModified); |                     var result = new HttpResult(new byte[] { }, contentType ?? "text/html", HttpStatusCode.NotModified); | ||||||
| 
 | 
 | ||||||
| @ -370,7 +370,7 @@ namespace Emby.Server.Implementations.HttpServer | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             AddCachingHeaders(responseHeaders, cacheKeyString, lastDateModified, cacheDuration, noCache); |             AddCachingHeaders(responseHeaders, cacheKeyString, lastDateModified, cacheDuration); | ||||||
| 
 | 
 | ||||||
|             return null; |             return null; | ||||||
|         } |         } | ||||||
| @ -555,7 +555,7 @@ namespace Emby.Server.Implementations.HttpServer | |||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Adds the caching responseHeaders. |         /// Adds the caching responseHeaders. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|         private void AddCachingHeaders(IDictionary<string, string> responseHeaders, string cacheKey, DateTime? lastDateModified, TimeSpan? cacheDuration, bool noCache) |         private void AddCachingHeaders(IDictionary<string, string> responseHeaders, string cacheKey, DateTime? lastDateModified, TimeSpan? cacheDuration) | ||||||
|         { |         { | ||||||
|             // Don't specify both last modified and Etag, unless caching unconditionally. They are redundant |             // Don't specify both last modified and Etag, unless caching unconditionally. They are redundant | ||||||
|             // https://developers.google.com/speed/docs/best-practices/caching#LeverageBrowserCaching |             // https://developers.google.com/speed/docs/best-practices/caching#LeverageBrowserCaching | ||||||
| @ -565,11 +565,11 @@ namespace Emby.Server.Implementations.HttpServer | |||||||
|                 responseHeaders["Last-Modified"] = lastDateModified.Value.ToString("r"); |                 responseHeaders["Last-Modified"] = lastDateModified.Value.ToString("r"); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (!noCache && cacheDuration.HasValue) |             if (cacheDuration.HasValue) | ||||||
|             { |             { | ||||||
|                 responseHeaders["Cache-Control"] = "public, max-age=" + Convert.ToInt32(cacheDuration.Value.TotalSeconds); |                 responseHeaders["Cache-Control"] = "public, max-age=" + Convert.ToInt32(cacheDuration.Value.TotalSeconds); | ||||||
|             } |             } | ||||||
|             else if (!noCache && !string.IsNullOrEmpty(cacheKey)) |             else if (!string.IsNullOrEmpty(cacheKey)) | ||||||
|             { |             { | ||||||
|                 responseHeaders["Cache-Control"] = "public"; |                 responseHeaders["Cache-Control"] = "public"; | ||||||
|             } |             } | ||||||
| @ -579,15 +579,15 @@ namespace Emby.Server.Implementations.HttpServer | |||||||
|                 responseHeaders["pragma"] = "no-cache, no-store, must-revalidate"; |                 responseHeaders["pragma"] = "no-cache, no-store, must-revalidate"; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             AddExpiresHeader(responseHeaders, cacheKey, cacheDuration, noCache); |             AddExpiresHeader(responseHeaders, cacheKey, cacheDuration); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Adds the expires header. |         /// Adds the expires header. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|         private void AddExpiresHeader(IDictionary<string, string> responseHeaders, string cacheKey, TimeSpan? cacheDuration, bool noCache) |         private void AddExpiresHeader(IDictionary<string, string> responseHeaders, string cacheKey, TimeSpan? cacheDuration) | ||||||
|         { |         { | ||||||
|             if (!noCache && cacheDuration.HasValue) |             if (cacheDuration.HasValue) | ||||||
|             { |             { | ||||||
|                 responseHeaders["Expires"] = DateTime.UtcNow.Add(cacheDuration.Value).ToString("r"); |                 responseHeaders["Expires"] = DateTime.UtcNow.Add(cacheDuration.Value).ToString("r"); | ||||||
|             } |             } | ||||||
|  | |||||||
| @ -32,6 +32,14 @@ namespace MediaBrowser.Controller.Channels | |||||||
|             return base.IsVisible(user); |             return base.IsVisible(user); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         public override double? GetDefaultPrimaryImageAspectRatio() | ||||||
|  |         { | ||||||
|  |             double value = 16; | ||||||
|  |             value /= 9; | ||||||
|  | 
 | ||||||
|  |             return value; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         [IgnoreDataMember] |         [IgnoreDataMember] | ||||||
|         public override bool SupportsInheritedParentImages |         public override bool SupportsInheritedParentImages | ||||||
|         { |         { | ||||||
|  | |||||||
| @ -117,8 +117,6 @@ namespace MediaBrowser.Controller.Drawing | |||||||
| 
 | 
 | ||||||
|         IImageEncoder ImageEncoder { get; set; } |         IImageEncoder ImageEncoder { get; set; } | ||||||
| 
 | 
 | ||||||
|         void SaveImageSize(string path, DateTime imageDateModified, ImageSize size); |  | ||||||
| 
 |  | ||||||
|         bool SupportsTransparency(string path); |         bool SupportsTransparency(string path); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -21,11 +21,6 @@ namespace MediaBrowser.Controller.Drawing | |||||||
| 
 | 
 | ||||||
|         public static IImageProcessor ImageProcessor { get; set; } |         public static IImageProcessor ImageProcessor { get; set; } | ||||||
| 
 | 
 | ||||||
|         public static void SaveImageSize(string path, DateTime dateModified, ImageSize size) |  | ||||||
|         { |  | ||||||
|             ImageProcessor.SaveImageSize(path, dateModified, size); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         private static ImageSize GetSizeEstimate(ImageProcessingOptions options) |         private static ImageSize GetSizeEstimate(ImageProcessingOptions options) | ||||||
|         { |         { | ||||||
|             if (options.Width.HasValue && options.Height.HasValue) |             if (options.Width.HasValue && options.Height.HasValue) | ||||||
|  | |||||||
| @ -15,7 +15,7 @@ namespace MediaBrowser.Controller.Entities.Audio | |||||||
| 
 | 
 | ||||||
|         public override double? GetDefaultPrimaryImageAspectRatio() |         public override double? GetDefaultPrimaryImageAspectRatio() | ||||||
|         { |         { | ||||||
|             return null; |             return 1; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -42,5 +42,13 @@ namespace MediaBrowser.Controller.Entities | |||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|  |         public override double? GetDefaultPrimaryImageAspectRatio() | ||||||
|  |         { | ||||||
|  |             double value = 16; | ||||||
|  |             value /= 9; | ||||||
|  | 
 | ||||||
|  |             return value; | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -31,6 +31,14 @@ namespace MediaBrowser.Controller.Entities | |||||||
|             PhysicalFolderIds = EmptyGuidArray; |             PhysicalFolderIds = EmptyGuidArray; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         public override double? GetDefaultPrimaryImageAspectRatio() | ||||||
|  |         { | ||||||
|  |             double value = 16; | ||||||
|  |             value /= 9; | ||||||
|  | 
 | ||||||
|  |             return value; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         [IgnoreDataMember] |         [IgnoreDataMember] | ||||||
|         public override bool SupportsPlayedStatus |         public override bool SupportsPlayedStatus | ||||||
|         { |         { | ||||||
|  | |||||||
| @ -22,6 +22,11 @@ namespace MediaBrowser.Controller.Entities | |||||||
|             return GetUserDataKeys()[0]; |             return GetUserDataKeys()[0]; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         public override double? GetDefaultPrimaryImageAspectRatio() | ||||||
|  |         { | ||||||
|  |             return 1; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Returns the folder containing the item. |         /// Returns the folder containing the item. | ||||||
|         /// If the item is a folder, it returns the folder itself |         /// If the item is a folder, it returns the folder itself | ||||||
|  | |||||||
| @ -44,6 +44,14 @@ namespace MediaBrowser.Controller.Entities | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         public override double? GetDefaultPrimaryImageAspectRatio() | ||||||
|  |         { | ||||||
|  |             double value = 16; | ||||||
|  |             value /= 9; | ||||||
|  | 
 | ||||||
|  |             return value; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Gets or sets the game system. |         /// Gets or sets the game system. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|  | |||||||
| @ -25,6 +25,11 @@ namespace MediaBrowser.Controller.Entities | |||||||
|             return GetUserDataKeys()[0]; |             return GetUserDataKeys()[0]; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         public override double? GetDefaultPrimaryImageAspectRatio() | ||||||
|  |         { | ||||||
|  |             return 1; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Returns the folder containing the item. |         /// Returns the folder containing the item. | ||||||
|         /// If the item is a folder, it returns the folder itself |         /// If the item is a folder, it returns the folder itself | ||||||
|  | |||||||
| @ -62,6 +62,35 @@ namespace MediaBrowser.Controller.Entities | |||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         public override double? GetDefaultPrimaryImageAspectRatio() | ||||||
|  |         { | ||||||
|  |             if (Width.HasValue && Height.HasValue) | ||||||
|  |             { | ||||||
|  |                 double width = Width.Value; | ||||||
|  |                 double height = Height.Value; | ||||||
|  | 
 | ||||||
|  |                 if (Orientation.HasValue) | ||||||
|  |                 { | ||||||
|  |                     switch (Orientation.Value) | ||||||
|  |                     { | ||||||
|  |                         case ImageOrientation.LeftBottom: | ||||||
|  |                         case ImageOrientation.LeftTop: | ||||||
|  |                         case ImageOrientation.RightBottom: | ||||||
|  |                         case ImageOrientation.RightTop: | ||||||
|  |                             var temp = height; | ||||||
|  |                             height = width; | ||||||
|  |                             width = temp; | ||||||
|  |                             break; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 width /= Height.Value; | ||||||
|  |                 return width; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return base.GetDefaultPrimaryImageAspectRatio(); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         public int? Width { get; set; } |         public int? Width { get; set; } | ||||||
|         public int? Height { get; set; } |         public int? Height { get; set; } | ||||||
|         public string CameraMake { get; set; } |         public string CameraMake { get; set; } | ||||||
|  | |||||||
| @ -30,5 +30,10 @@ namespace MediaBrowser.Controller.Entities | |||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|  |         public override double? GetDefaultPrimaryImageAspectRatio() | ||||||
|  |         { | ||||||
|  |             return 1; | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -254,6 +254,11 @@ namespace MediaBrowser.Controller.Entities | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         public override double? GetDefaultPrimaryImageAspectRatio() | ||||||
|  |         { | ||||||
|  |             return 1; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Gets the configuration directory path. |         /// Gets the configuration directory path. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|  | |||||||
| @ -58,6 +58,14 @@ namespace MediaBrowser.Controller.Entities | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         public override double? GetDefaultPrimaryImageAspectRatio() | ||||||
|  |         { | ||||||
|  |             double value = 16; | ||||||
|  |             value /= 9; | ||||||
|  | 
 | ||||||
|  |             return value; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         public override int GetChildCount(User user) |         public override int GetChildCount(User user) | ||||||
|         { |         { | ||||||
|             return GetChildren(user, true).Count; |             return GetChildren(user, true).Count; | ||||||
|  | |||||||
| @ -32,6 +32,14 @@ namespace MediaBrowser.Controller.Entities | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         public override double? GetDefaultPrimaryImageAspectRatio() | ||||||
|  |         { | ||||||
|  |             double value = 2; | ||||||
|  |             value /= 3; | ||||||
|  | 
 | ||||||
|  |             return value; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         [IgnoreDataMember] |         [IgnoreDataMember] | ||||||
|         public override bool SupportsAncestors |         public override bool SupportsAncestors | ||||||
|         { |         { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user