mirror of
https://github.com/jellyfin/jellyfin.git
synced 2025-07-09 03:04:24 -04:00
update images
This commit is contained in:
parent
492f897f81
commit
32babe2b94
@ -104,6 +104,7 @@ namespace Emby.Drawing.ImageMagick
|
|||||||
wand.CurrentImage.TrimImage(10);
|
wand.CurrentImage.TrimImage(10);
|
||||||
wand.SaveImage(outputPath);
|
wand.SaveImage(outputPath);
|
||||||
}
|
}
|
||||||
|
SaveDelay();
|
||||||
}
|
}
|
||||||
|
|
||||||
public ImageSize GetImageSize(string path)
|
public ImageSize GetImageSize(string path)
|
||||||
@ -163,6 +164,7 @@ namespace Emby.Drawing.ImageMagick
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
SaveDelay();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -223,6 +225,15 @@ namespace Emby.Drawing.ImageMagick
|
|||||||
{
|
{
|
||||||
new StripCollageBuilder(_appPaths, _fileSystem).BuildPosterCollage(options.InputPaths.ToList(), options.OutputPath, options.Width, options.Height, options.Text);
|
new StripCollageBuilder(_appPaths, _fileSystem).BuildPosterCollage(options.InputPaths.ToList(), options.OutputPath, options.Width, options.Height, options.Text);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SaveDelay();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void SaveDelay()
|
||||||
|
{
|
||||||
|
// For some reason the images are not always getting released right away
|
||||||
|
var task = Task.Delay(300);
|
||||||
|
Task.WaitAll(task);
|
||||||
}
|
}
|
||||||
|
|
||||||
public string Name
|
public string Name
|
||||||
|
@ -238,9 +238,6 @@ namespace Emby.Drawing
|
|||||||
imageProcessingLockTaken = true;
|
imageProcessingLockTaken = true;
|
||||||
|
|
||||||
_imageEncoder.EncodeImage(originalImagePath, cacheFilePath, newWidth, newHeight, quality, options);
|
_imageEncoder.EncodeImage(originalImagePath, cacheFilePath, newWidth, newHeight, quality, options);
|
||||||
|
|
||||||
// ImageMagick doesn't seem to always release it right away
|
|
||||||
await Task.Delay(300).ConfigureAwait(false);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
|
@ -7,7 +7,5 @@ namespace MediaBrowser.Controller.Channels
|
|||||||
string ChannelId { get; set; }
|
string ChannelId { get; set; }
|
||||||
|
|
||||||
string ExternalId { get; set; }
|
string ExternalId { get; set; }
|
||||||
|
|
||||||
string ExternalImagePath { get; set; }
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -185,13 +185,6 @@ namespace MediaBrowser.Controller.Entities
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Supply the image path if it can be accessed directly from the file system
|
|
||||||
/// </summary>
|
|
||||||
/// <value>The image path.</value>
|
|
||||||
[IgnoreDataMember]
|
|
||||||
public string ExternalImagePath { get; set; }
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Gets or sets the etag.
|
/// Gets or sets the etag.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -246,8 +246,19 @@ namespace MediaBrowser.Controller.Entities
|
|||||||
/// <param name="imageType">Type of the image.</param>
|
/// <param name="imageType">Type of the image.</param>
|
||||||
/// <param name="file">The file.</param>
|
/// <param name="file">The file.</param>
|
||||||
public static void SetImagePath(this IHasImages item, ImageType imageType, string file)
|
public static void SetImagePath(this IHasImages item, ImageType imageType, string file)
|
||||||
|
{
|
||||||
|
if (file.StartsWith("http", System.StringComparison.OrdinalIgnoreCase))
|
||||||
|
{
|
||||||
|
item.SetImage(new ItemImageInfo
|
||||||
|
{
|
||||||
|
Path = file,
|
||||||
|
Type = imageType
|
||||||
|
}, 0);
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
item.SetImagePath(imageType, BaseItem.FileSystem.GetFileInfo(file));
|
item.SetImagePath(imageType, BaseItem.FileSystem.GetFileInfo(file));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,8 +30,6 @@ namespace MediaBrowser.Controller.LiveTv
|
|||||||
|
|
||||||
bool CanDelete(User user);
|
bool CanDelete(User user);
|
||||||
|
|
||||||
string ExternalImagePath { get; set; }
|
|
||||||
|
|
||||||
string SeriesTimerId { get; set; }
|
string SeriesTimerId { get; set; }
|
||||||
RecordingStatus Status { get; set; }
|
RecordingStatus Status { get; set; }
|
||||||
DateTime? EndDate { get; set; }
|
DateTime? EndDate { get; set; }
|
||||||
|
@ -1,68 +0,0 @@
|
|||||||
using MediaBrowser.Common.Net;
|
|
||||||
using MediaBrowser.Controller.Channels;
|
|
||||||
using MediaBrowser.Controller.Entities;
|
|
||||||
using MediaBrowser.Controller.Providers;
|
|
||||||
using MediaBrowser.Model.Entities;
|
|
||||||
using MediaBrowser.Model.Logging;
|
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Threading;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using MediaBrowser.Model.MediaInfo;
|
|
||||||
|
|
||||||
namespace MediaBrowser.Server.Implementations.Channels
|
|
||||||
{
|
|
||||||
public class ChannelItemImageProvider : IDynamicImageProvider, IHasItemChangeMonitor
|
|
||||||
{
|
|
||||||
private readonly IHttpClient _httpClient;
|
|
||||||
private readonly ILogger _logger;
|
|
||||||
|
|
||||||
public ChannelItemImageProvider(IHttpClient httpClient, ILogger logger)
|
|
||||||
{
|
|
||||||
_httpClient = httpClient;
|
|
||||||
_logger = logger;
|
|
||||||
}
|
|
||||||
|
|
||||||
public IEnumerable<ImageType> GetSupportedImages(IHasImages item)
|
|
||||||
{
|
|
||||||
return new[] { ImageType.Primary };
|
|
||||||
}
|
|
||||||
|
|
||||||
public async Task<DynamicImageResponse> GetImage(IHasImages item, ImageType type, CancellationToken cancellationToken)
|
|
||||||
{
|
|
||||||
var channelItem = (IChannelItem)item;
|
|
||||||
|
|
||||||
var imageResponse = new DynamicImageResponse();
|
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(channelItem.ExternalImagePath))
|
|
||||||
{
|
|
||||||
imageResponse.Path = channelItem.ExternalImagePath;
|
|
||||||
imageResponse.Protocol = MediaProtocol.Http;
|
|
||||||
imageResponse.HasImage = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return imageResponse;
|
|
||||||
}
|
|
||||||
|
|
||||||
public string Name
|
|
||||||
{
|
|
||||||
get { return "Channel Image Provider"; }
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool Supports(IHasImages item)
|
|
||||||
{
|
|
||||||
return item is IChannelItem;
|
|
||||||
}
|
|
||||||
|
|
||||||
public bool HasChanged(IHasMetadata item, MetadataStatus status, IDirectoryService directoryService)
|
|
||||||
{
|
|
||||||
var channelItem = item as IChannelItem;
|
|
||||||
|
|
||||||
if (channelItem != null)
|
|
||||||
{
|
|
||||||
return !channelItem.HasImage(ImageType.Primary) && !string.IsNullOrWhiteSpace(channelItem.ExternalImagePath);
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -216,9 +216,7 @@ namespace MediaBrowser.Server.Implementations.Channels
|
|||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
var item = await GetChannel(channelInfo, cancellationToken).ConfigureAwait(false);
|
await GetChannel(channelInfo, cancellationToken).ConfigureAwait(false);
|
||||||
|
|
||||||
_libraryManager.RegisterItem(item);
|
|
||||||
}
|
}
|
||||||
catch (OperationCanceledException)
|
catch (OperationCanceledException)
|
||||||
{
|
{
|
||||||
@ -246,8 +244,6 @@ namespace MediaBrowser.Server.Implementations.Channels
|
|||||||
if (item == null)
|
if (item == null)
|
||||||
{
|
{
|
||||||
item = GetChannel(channel, CancellationToken.None).Result;
|
item = GetChannel(channel, CancellationToken.None).Result;
|
||||||
|
|
||||||
_libraryManager.RegisterItem(item);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return item;
|
return item;
|
||||||
@ -1264,7 +1260,6 @@ namespace MediaBrowser.Server.Implementations.Channels
|
|||||||
|
|
||||||
var channelItem = (IChannelItem)item;
|
var channelItem = (IChannelItem)item;
|
||||||
|
|
||||||
channelItem.ExternalImagePath = info.ImageUrl;
|
|
||||||
channelItem.ChannelId = internalChannelId.ToString("N");
|
channelItem.ChannelId = internalChannelId.ToString("N");
|
||||||
|
|
||||||
if (!string.Equals(channelItem.ExternalId, info.Id, StringComparison.OrdinalIgnoreCase))
|
if (!string.Equals(channelItem.ExternalId, info.Id, StringComparison.OrdinalIgnoreCase))
|
||||||
@ -1291,13 +1286,20 @@ namespace MediaBrowser.Server.Implementations.Channels
|
|||||||
item.Path = mediaSource == null ? null : mediaSource.Path;
|
item.Path = mediaSource == null ? null : mediaSource.Path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!string.IsNullOrWhiteSpace(info.ImageUrl))
|
||||||
|
{
|
||||||
|
item.SetImagePath(ImageType.Primary, info.ImageUrl);
|
||||||
|
}
|
||||||
|
|
||||||
if (isNew)
|
if (isNew)
|
||||||
{
|
{
|
||||||
await _libraryManager.CreateItem(item, cancellationToken).ConfigureAwait(false);
|
await _libraryManager.CreateItem(item, cancellationToken).ConfigureAwait(false);
|
||||||
_libraryManager.RegisterItem(item);
|
|
||||||
|
|
||||||
|
if (info.People != null && info.People.Count > 0)
|
||||||
|
{
|
||||||
await _libraryManager.UpdatePeople(item, info.People ?? new List<PersonInfo>()).ConfigureAwait(false);
|
await _libraryManager.UpdatePeople(item, info.People ?? new List<PersonInfo>()).ConfigureAwait(false);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return item;
|
return item;
|
||||||
}
|
}
|
||||||
|
@ -39,40 +39,6 @@ namespace MediaBrowser.Server.Implementations.LiveTv
|
|||||||
|
|
||||||
var imageResponse = new DynamicImageResponse();
|
var imageResponse = new DynamicImageResponse();
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(liveTvItem.ExternalImagePath))
|
|
||||||
{
|
|
||||||
if (liveTvItem.ExternalImagePath.StartsWith("http", StringComparison.OrdinalIgnoreCase))
|
|
||||||
{
|
|
||||||
var options = new HttpRequestOptions
|
|
||||||
{
|
|
||||||
CancellationToken = cancellationToken,
|
|
||||||
Url = liveTvItem.ExternalImagePath,
|
|
||||||
|
|
||||||
// Some image hosts require a user agent to be specified.
|
|
||||||
UserAgent = "Emby Server/" + _appHost.ApplicationVersion
|
|
||||||
};
|
|
||||||
|
|
||||||
var response = await _httpClient.GetResponse(options).ConfigureAwait(false);
|
|
||||||
|
|
||||||
if (response.ContentType.StartsWith("image/", StringComparison.OrdinalIgnoreCase))
|
|
||||||
{
|
|
||||||
imageResponse.HasImage = true;
|
|
||||||
imageResponse.Stream = response.Content;
|
|
||||||
imageResponse.SetFormatFromMimeType(response.ContentType);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
_logger.Error("Provider did not return an image content type.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
imageResponse.Path = liveTvItem.ExternalImagePath;
|
|
||||||
imageResponse.HasImage = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
var service = _liveTvManager.Services.FirstOrDefault(i => string.Equals(i.Name, liveTvItem.ServiceName, StringComparison.OrdinalIgnoreCase));
|
var service = _liveTvManager.Services.FirstOrDefault(i => string.Equals(i.Name, liveTvItem.ServiceName, StringComparison.OrdinalIgnoreCase));
|
||||||
|
|
||||||
if (service != null)
|
if (service != null)
|
||||||
@ -92,7 +58,6 @@ namespace MediaBrowser.Server.Implementations.LiveTv
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return imageResponse;
|
return imageResponse;
|
||||||
}
|
}
|
||||||
|
@ -577,7 +577,14 @@ namespace MediaBrowser.Server.Implementations.LiveTv
|
|||||||
// replaceImages.Add(ImageType.Primary);
|
// replaceImages.Add(ImageType.Primary);
|
||||||
//}
|
//}
|
||||||
|
|
||||||
item.ExternalImagePath = string.IsNullOrWhiteSpace(channelInfo.ImageUrl) ? channelInfo.ImagePath : channelInfo.ImageUrl;
|
if (!string.IsNullOrWhiteSpace(channelInfo.ImagePath))
|
||||||
|
{
|
||||||
|
item.SetImagePath(ImageType.Primary, channelInfo.ImagePath);
|
||||||
|
}
|
||||||
|
else if (!string.IsNullOrWhiteSpace(channelInfo.ImageUrl))
|
||||||
|
{
|
||||||
|
item.SetImagePath(ImageType.Primary, channelInfo.ImageUrl);
|
||||||
|
}
|
||||||
|
|
||||||
if (string.IsNullOrEmpty(item.Name))
|
if (string.IsNullOrEmpty(item.Name))
|
||||||
{
|
{
|
||||||
@ -636,7 +643,6 @@ namespace MediaBrowser.Server.Implementations.LiveTv
|
|||||||
item.Name = info.Name;
|
item.Name = info.Name;
|
||||||
item.OfficialRating = item.OfficialRating ?? info.OfficialRating;
|
item.OfficialRating = item.OfficialRating ?? info.OfficialRating;
|
||||||
item.Overview = item.Overview ?? info.Overview;
|
item.Overview = item.Overview ?? info.Overview;
|
||||||
item.ExternalImagePath = string.IsNullOrWhiteSpace(info.ImagePath) ? info.ImageUrl : info.ImagePath;
|
|
||||||
item.RunTimeTicks = (info.EndDate - info.StartDate).Ticks;
|
item.RunTimeTicks = (info.EndDate - info.StartDate).Ticks;
|
||||||
item.StartDate = info.StartDate;
|
item.StartDate = info.StartDate;
|
||||||
item.HomePageUrl = info.HomePageUrl;
|
item.HomePageUrl = info.HomePageUrl;
|
||||||
@ -647,6 +653,15 @@ namespace MediaBrowser.Server.Implementations.LiveTv
|
|||||||
item.IndexNumber = info.EpisodeNumber;
|
item.IndexNumber = info.EpisodeNumber;
|
||||||
item.ParentIndexNumber = info.SeasonNumber;
|
item.ParentIndexNumber = info.SeasonNumber;
|
||||||
|
|
||||||
|
if (!string.IsNullOrWhiteSpace(info.ImagePath))
|
||||||
|
{
|
||||||
|
item.SetImagePath(ImageType.Primary, info.ImagePath);
|
||||||
|
}
|
||||||
|
else if (!string.IsNullOrWhiteSpace(info.ImageUrl))
|
||||||
|
{
|
||||||
|
item.SetImagePath(ImageType.Primary, info.ImageUrl);
|
||||||
|
}
|
||||||
|
|
||||||
if (isNew)
|
if (isNew)
|
||||||
{
|
{
|
||||||
await _libraryManager.CreateItem(item, cancellationToken).ConfigureAwait(false);
|
await _libraryManager.CreateItem(item, cancellationToken).ConfigureAwait(false);
|
||||||
@ -722,7 +737,6 @@ namespace MediaBrowser.Server.Implementations.LiveTv
|
|||||||
recording.Audio = info.Audio;
|
recording.Audio = info.Audio;
|
||||||
recording.EndDate = info.EndDate;
|
recording.EndDate = info.EndDate;
|
||||||
recording.EpisodeTitle = info.EpisodeTitle;
|
recording.EpisodeTitle = info.EpisodeTitle;
|
||||||
recording.ExternalImagePath = string.IsNullOrWhiteSpace(info.ImagePath) ? info.ImageUrl : info.ImagePath;
|
|
||||||
recording.IsHD = info.IsHD;
|
recording.IsHD = info.IsHD;
|
||||||
recording.IsKids = info.IsKids;
|
recording.IsKids = info.IsKids;
|
||||||
recording.IsLive = info.IsLive;
|
recording.IsLive = info.IsLive;
|
||||||
@ -735,6 +749,15 @@ namespace MediaBrowser.Server.Implementations.LiveTv
|
|||||||
recording.SeriesTimerId = info.SeriesTimerId;
|
recording.SeriesTimerId = info.SeriesTimerId;
|
||||||
recording.StartDate = info.StartDate;
|
recording.StartDate = info.StartDate;
|
||||||
|
|
||||||
|
if (!string.IsNullOrWhiteSpace(info.ImagePath))
|
||||||
|
{
|
||||||
|
item.SetImagePath(ImageType.Primary, info.ImagePath);
|
||||||
|
}
|
||||||
|
else if (!string.IsNullOrWhiteSpace(info.ImageUrl))
|
||||||
|
{
|
||||||
|
item.SetImagePath(ImageType.Primary, info.ImageUrl);
|
||||||
|
}
|
||||||
|
|
||||||
var statusChanged = info.Status != recording.Status;
|
var statusChanged = info.Status != recording.Status;
|
||||||
|
|
||||||
recording.Status = info.Status;
|
recording.Status = info.Status;
|
||||||
@ -1830,7 +1853,7 @@ namespace MediaBrowser.Server.Implementations.LiveTv
|
|||||||
OriginalAirDate = program.PremiereDate,
|
OriginalAirDate = program.PremiereDate,
|
||||||
Overview = program.Overview,
|
Overview = program.Overview,
|
||||||
StartDate = program.StartDate,
|
StartDate = program.StartDate,
|
||||||
ImagePath = program.ExternalImagePath,
|
//ImagePath = program.ExternalImagePath,
|
||||||
Name = program.Name,
|
Name = program.Name,
|
||||||
OfficialRating = program.OfficialRating
|
OfficialRating = program.OfficialRating
|
||||||
};
|
};
|
||||||
|
@ -1,29 +1,22 @@
|
|||||||
using MediaBrowser.Common.Net;
|
using MediaBrowser.Controller.Entities;
|
||||||
using MediaBrowser.Controller.Entities;
|
|
||||||
using MediaBrowser.Controller.LiveTv;
|
using MediaBrowser.Controller.LiveTv;
|
||||||
using MediaBrowser.Controller.Providers;
|
using MediaBrowser.Controller.Providers;
|
||||||
using MediaBrowser.Model.Entities;
|
using MediaBrowser.Model.Entities;
|
||||||
using MediaBrowser.Model.Logging;
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
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 MediaBrowser.Model.MediaInfo;
|
|
||||||
|
|
||||||
namespace MediaBrowser.Server.Implementations.LiveTv
|
namespace MediaBrowser.Server.Implementations.LiveTv
|
||||||
{
|
{
|
||||||
public class ProgramImageProvider : IDynamicImageProvider, IHasItemChangeMonitor, IHasOrder
|
public class ProgramImageProvider : IDynamicImageProvider, IHasItemChangeMonitor, IHasOrder
|
||||||
{
|
{
|
||||||
private readonly ILiveTvManager _liveTvManager;
|
private readonly ILiveTvManager _liveTvManager;
|
||||||
private readonly IHttpClient _httpClient;
|
|
||||||
private readonly ILogger _logger;
|
|
||||||
|
|
||||||
public ProgramImageProvider(ILiveTvManager liveTvManager, IHttpClient httpClient, ILogger logger)
|
public ProgramImageProvider(ILiveTvManager liveTvManager)
|
||||||
{
|
{
|
||||||
_liveTvManager = liveTvManager;
|
_liveTvManager = liveTvManager;
|
||||||
_httpClient = httpClient;
|
|
||||||
_logger = logger;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public IEnumerable<ImageType> GetSupportedImages(IHasImages item)
|
public IEnumerable<ImageType> GetSupportedImages(IHasImages item)
|
||||||
@ -37,22 +30,6 @@ namespace MediaBrowser.Server.Implementations.LiveTv
|
|||||||
|
|
||||||
var imageResponse = new DynamicImageResponse();
|
var imageResponse = new DynamicImageResponse();
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(liveTvItem.ExternalImagePath))
|
|
||||||
{
|
|
||||||
if (liveTvItem.ExternalImagePath.StartsWith("http", StringComparison.OrdinalIgnoreCase))
|
|
||||||
{
|
|
||||||
imageResponse.Path = liveTvItem.ExternalImagePath;
|
|
||||||
imageResponse.Protocol = MediaProtocol.Http;
|
|
||||||
imageResponse.HasImage = true;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
imageResponse.Path = liveTvItem.ExternalImagePath;
|
|
||||||
imageResponse.HasImage = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
var service = _liveTvManager.Services.FirstOrDefault(i => string.Equals(i.Name, liveTvItem.ServiceName, StringComparison.OrdinalIgnoreCase));
|
var service = _liveTvManager.Services.FirstOrDefault(i => string.Equals(i.Name, liveTvItem.ServiceName, StringComparison.OrdinalIgnoreCase));
|
||||||
|
|
||||||
if (service != null)
|
if (service != null)
|
||||||
@ -74,7 +51,6 @@ namespace MediaBrowser.Server.Implementations.LiveTv
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return imageResponse;
|
return imageResponse;
|
||||||
}
|
}
|
||||||
|
@ -1,9 +1,7 @@
|
|||||||
using MediaBrowser.Common.Net;
|
using MediaBrowser.Controller.Entities;
|
||||||
using MediaBrowser.Controller.Entities;
|
|
||||||
using MediaBrowser.Controller.LiveTv;
|
using MediaBrowser.Controller.LiveTv;
|
||||||
using MediaBrowser.Controller.Providers;
|
using MediaBrowser.Controller.Providers;
|
||||||
using MediaBrowser.Model.Entities;
|
using MediaBrowser.Model.Entities;
|
||||||
using MediaBrowser.Model.Logging;
|
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
@ -15,14 +13,10 @@ namespace MediaBrowser.Server.Implementations.LiveTv
|
|||||||
public class RecordingImageProvider : IDynamicImageProvider, IHasItemChangeMonitor
|
public class RecordingImageProvider : IDynamicImageProvider, IHasItemChangeMonitor
|
||||||
{
|
{
|
||||||
private readonly ILiveTvManager _liveTvManager;
|
private readonly ILiveTvManager _liveTvManager;
|
||||||
private readonly IHttpClient _httpClient;
|
|
||||||
private readonly ILogger _logger;
|
|
||||||
|
|
||||||
public RecordingImageProvider(ILiveTvManager liveTvManager, IHttpClient httpClient, ILogger logger)
|
public RecordingImageProvider(ILiveTvManager liveTvManager)
|
||||||
{
|
{
|
||||||
_liveTvManager = liveTvManager;
|
_liveTvManager = liveTvManager;
|
||||||
_httpClient = httpClient;
|
|
||||||
_logger = logger;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public IEnumerable<ImageType> GetSupportedImages(IHasImages item)
|
public IEnumerable<ImageType> GetSupportedImages(IHasImages item)
|
||||||
@ -36,37 +30,6 @@ namespace MediaBrowser.Server.Implementations.LiveTv
|
|||||||
|
|
||||||
var imageResponse = new DynamicImageResponse();
|
var imageResponse = new DynamicImageResponse();
|
||||||
|
|
||||||
if (!string.IsNullOrEmpty(liveTvItem.ExternalImagePath))
|
|
||||||
{
|
|
||||||
if (liveTvItem.ExternalImagePath.StartsWith("http", StringComparison.OrdinalIgnoreCase))
|
|
||||||
{
|
|
||||||
var options = new HttpRequestOptions
|
|
||||||
{
|
|
||||||
CancellationToken = cancellationToken,
|
|
||||||
Url = liveTvItem.ExternalImagePath
|
|
||||||
};
|
|
||||||
|
|
||||||
var response = await _httpClient.GetResponse(options).ConfigureAwait(false);
|
|
||||||
|
|
||||||
if (response.ContentType.StartsWith("image/", StringComparison.OrdinalIgnoreCase))
|
|
||||||
{
|
|
||||||
imageResponse.HasImage = true;
|
|
||||||
imageResponse.Stream = response.Content;
|
|
||||||
imageResponse.SetFormatFromMimeType(response.ContentType);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
_logger.Error("Provider did not return an image content type.");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
imageResponse.Path = liveTvItem.ExternalImagePath;
|
|
||||||
imageResponse.HasImage = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
var service = _liveTvManager.Services.FirstOrDefault(i => string.Equals(i.Name, liveTvItem.ServiceName, StringComparison.OrdinalIgnoreCase));
|
var service = _liveTvManager.Services.FirstOrDefault(i => string.Equals(i.Name, liveTvItem.ServiceName, StringComparison.OrdinalIgnoreCase));
|
||||||
|
|
||||||
if (service != null)
|
if (service != null)
|
||||||
@ -86,7 +49,6 @@ namespace MediaBrowser.Server.Implementations.LiveTv
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return imageResponse;
|
return imageResponse;
|
||||||
}
|
}
|
||||||
|
@ -108,7 +108,6 @@
|
|||||||
<Compile Include="Channels\ChannelConfigurations.cs" />
|
<Compile Include="Channels\ChannelConfigurations.cs" />
|
||||||
<Compile Include="Channels\ChannelDynamicMediaSourceProvider.cs" />
|
<Compile Include="Channels\ChannelDynamicMediaSourceProvider.cs" />
|
||||||
<Compile Include="Channels\ChannelImageProvider.cs" />
|
<Compile Include="Channels\ChannelImageProvider.cs" />
|
||||||
<Compile Include="Channels\ChannelItemImageProvider.cs" />
|
|
||||||
<Compile Include="Channels\ChannelManager.cs" />
|
<Compile Include="Channels\ChannelManager.cs" />
|
||||||
<Compile Include="Channels\ChannelPostScanTask.cs" />
|
<Compile Include="Channels\ChannelPostScanTask.cs" />
|
||||||
<Compile Include="Channels\RefreshChannelsScheduledTask.cs" />
|
<Compile Include="Channels\RefreshChannelsScheduledTask.cs" />
|
||||||
|
@ -196,7 +196,6 @@ namespace MediaBrowser.Server.Implementations.Persistence
|
|||||||
_connection.AddColumn(_logger, "TypedBaseItems", "PreferredMetadataCountryCode", "Text");
|
_connection.AddColumn(_logger, "TypedBaseItems", "PreferredMetadataCountryCode", "Text");
|
||||||
_connection.AddColumn(_logger, "TypedBaseItems", "IsHD", "BIT");
|
_connection.AddColumn(_logger, "TypedBaseItems", "IsHD", "BIT");
|
||||||
_connection.AddColumn(_logger, "TypedBaseItems", "ExternalEtag", "Text");
|
_connection.AddColumn(_logger, "TypedBaseItems", "ExternalEtag", "Text");
|
||||||
_connection.AddColumn(_logger, "TypedBaseItems", "ExternalImagePath", "Text");
|
|
||||||
_connection.AddColumn(_logger, "TypedBaseItems", "DateLastRefreshed", "DATETIME");
|
_connection.AddColumn(_logger, "TypedBaseItems", "DateLastRefreshed", "DATETIME");
|
||||||
|
|
||||||
PrepareStatements();
|
PrepareStatements();
|
||||||
@ -290,7 +289,6 @@ namespace MediaBrowser.Server.Implementations.Persistence
|
|||||||
"PreferredMetadataCountryCode",
|
"PreferredMetadataCountryCode",
|
||||||
"IsHD",
|
"IsHD",
|
||||||
"ExternalEtag",
|
"ExternalEtag",
|
||||||
"ExternalImagePath",
|
|
||||||
"DateLastRefreshed"
|
"DateLastRefreshed"
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -378,7 +376,6 @@ namespace MediaBrowser.Server.Implementations.Persistence
|
|||||||
"PreferredMetadataCountryCode",
|
"PreferredMetadataCountryCode",
|
||||||
"IsHD",
|
"IsHD",
|
||||||
"ExternalEtag",
|
"ExternalEtag",
|
||||||
"ExternalImagePath",
|
|
||||||
"DateLastRefreshed"
|
"DateLastRefreshed"
|
||||||
};
|
};
|
||||||
_saveItemCommand = _connection.CreateCommand();
|
_saveItemCommand = _connection.CreateCommand();
|
||||||
@ -598,7 +595,6 @@ namespace MediaBrowser.Server.Implementations.Persistence
|
|||||||
_saveItemCommand.GetParameter(index++).Value = item.PreferredMetadataCountryCode;
|
_saveItemCommand.GetParameter(index++).Value = item.PreferredMetadataCountryCode;
|
||||||
_saveItemCommand.GetParameter(index++).Value = item.IsHD;
|
_saveItemCommand.GetParameter(index++).Value = item.IsHD;
|
||||||
_saveItemCommand.GetParameter(index++).Value = item.ExternalEtag;
|
_saveItemCommand.GetParameter(index++).Value = item.ExternalEtag;
|
||||||
_saveItemCommand.GetParameter(index++).Value = item.ExternalImagePath;
|
|
||||||
|
|
||||||
if (item.DateLastRefreshed == default(DateTime))
|
if (item.DateLastRefreshed == default(DateTime))
|
||||||
{
|
{
|
||||||
@ -827,12 +823,7 @@ namespace MediaBrowser.Server.Implementations.Persistence
|
|||||||
|
|
||||||
if (!reader.IsDBNull(23))
|
if (!reader.IsDBNull(23))
|
||||||
{
|
{
|
||||||
item.ExternalImagePath = reader.GetString(23);
|
item.DateLastRefreshed = reader.GetDateTime(23).ToUniversalTime();
|
||||||
}
|
|
||||||
|
|
||||||
if (!reader.IsDBNull(24))
|
|
||||||
{
|
|
||||||
item.DateLastRefreshed = reader.GetDateTime(24).ToUniversalTime();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return item;
|
return item;
|
||||||
|
@ -330,11 +330,6 @@ namespace MediaBrowser.ServerApplication
|
|||||||
_logger.Info("Shutting down");
|
_logger.Info("Shutting down");
|
||||||
|
|
||||||
_appHost.Dispose();
|
_appHost.Dispose();
|
||||||
|
|
||||||
if (!_isRunningAsService)
|
|
||||||
{
|
|
||||||
SetErrorMode(ErrorModes.SYSTEM_DEFAULT);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user