|
@@ -1,5 +1,4 @@
|
|
|
using MediaBrowser.Common.Extensions;
|
|
|
-using MediaBrowser.Common.IO;
|
|
|
using MediaBrowser.Controller.Configuration;
|
|
|
using MediaBrowser.Controller.Entities;
|
|
|
using MediaBrowser.Controller.Library;
|
|
@@ -12,11 +11,6 @@ using System.Linq;
|
|
|
using System.Threading;
|
|
|
using System.Threading.Tasks;
|
|
|
using CommonIO;
|
|
|
-using MediaBrowser.Controller.Channels;
|
|
|
-using MediaBrowser.Controller.Entities.Audio;
|
|
|
-using MediaBrowser.Controller.Entities.Movies;
|
|
|
-using MediaBrowser.Controller.LiveTv;
|
|
|
-using MediaBrowser.Controller.Playlists;
|
|
|
using MediaBrowser.Model.Providers;
|
|
|
|
|
|
namespace MediaBrowser.Providers.Manager
|
|
@@ -28,95 +22,26 @@ namespace MediaBrowser.Providers.Manager
|
|
|
protected readonly IServerConfigurationManager ServerConfigurationManager;
|
|
|
protected readonly ILogger Logger;
|
|
|
protected readonly IProviderManager ProviderManager;
|
|
|
- protected readonly IProviderRepository ProviderRepo;
|
|
|
protected readonly IFileSystem FileSystem;
|
|
|
protected readonly IUserDataManager UserDataManager;
|
|
|
protected readonly ILibraryManager LibraryManager;
|
|
|
|
|
|
- protected MetadataService(IServerConfigurationManager serverConfigurationManager, ILogger logger, IProviderManager providerManager, IProviderRepository providerRepo, IFileSystem fileSystem, IUserDataManager userDataManager, ILibraryManager libraryManager)
|
|
|
+ protected MetadataService(IServerConfigurationManager serverConfigurationManager, ILogger logger, IProviderManager providerManager, IFileSystem fileSystem, IUserDataManager userDataManager, ILibraryManager libraryManager)
|
|
|
{
|
|
|
ServerConfigurationManager = serverConfigurationManager;
|
|
|
Logger = logger;
|
|
|
ProviderManager = providerManager;
|
|
|
- ProviderRepo = providerRepo;
|
|
|
FileSystem = fileSystem;
|
|
|
UserDataManager = userDataManager;
|
|
|
LibraryManager = libraryManager;
|
|
|
}
|
|
|
|
|
|
- /// <summary>
|
|
|
- /// Saves the provider result.
|
|
|
- /// </summary>
|
|
|
- /// <param name="item">The item.</param>
|
|
|
- /// <param name="result">The result.</param>
|
|
|
- /// <param name="directoryService">The directory service.</param>
|
|
|
- /// <returns>Task.</returns>
|
|
|
- protected Task SaveProviderResult(TItemType item, MetadataStatus result, IDirectoryService directoryService)
|
|
|
- {
|
|
|
- result.ItemId = item.Id;
|
|
|
-
|
|
|
- //var locationType = item.LocationType;
|
|
|
-
|
|
|
- //if (locationType == LocationType.FileSystem || locationType == LocationType.Offline)
|
|
|
- //{
|
|
|
- // if (!string.IsNullOrWhiteSpace(item.Path))
|
|
|
- // {
|
|
|
- // var file = directoryService.GetFile(item.Path);
|
|
|
-
|
|
|
- // if ((file.Attributes & FileAttributes.Directory) != FileAttributes.Directory && file.Exists)
|
|
|
- // {
|
|
|
- // result.ItemDateModified = FileSystem.GetLastWriteTimeUtc(file);
|
|
|
- // }
|
|
|
- // }
|
|
|
- //}
|
|
|
-
|
|
|
- result.ItemDateModified = item.DateModified;
|
|
|
-
|
|
|
- if (EnableDateLastRefreshed(item))
|
|
|
- {
|
|
|
- return Task.FromResult(true);
|
|
|
- }
|
|
|
-
|
|
|
- return ProviderRepo.SaveMetadataStatus(result, CancellationToken.None);
|
|
|
- }
|
|
|
-
|
|
|
- /// <summary>
|
|
|
- /// Gets the last result.
|
|
|
- /// </summary>
|
|
|
- /// <param name="item">The item.</param>
|
|
|
- /// <returns>ProviderResult.</returns>
|
|
|
- protected MetadataStatus GetLastResult(IHasMetadata item)
|
|
|
- {
|
|
|
- if (GetLastRefreshDate(item) == default(DateTime))
|
|
|
- {
|
|
|
- return new MetadataStatus { ItemId = item.Id };
|
|
|
- }
|
|
|
-
|
|
|
- if (EnableDateLastRefreshed(item) && item.DateModifiedDuringLastRefresh.HasValue)
|
|
|
- {
|
|
|
- return new MetadataStatus
|
|
|
- {
|
|
|
- ItemId = item.Id,
|
|
|
- DateLastImagesRefresh = item.DateLastRefreshed,
|
|
|
- DateLastMetadataRefresh = item.DateLastRefreshed,
|
|
|
- ItemDateModified = item.DateModifiedDuringLastRefresh.Value
|
|
|
- };
|
|
|
- }
|
|
|
-
|
|
|
- var result = ProviderRepo.GetMetadataStatus(item.Id) ?? new MetadataStatus { ItemId = item.Id };
|
|
|
-
|
|
|
- item.DateModifiedDuringLastRefresh = result.ItemDateModified;
|
|
|
-
|
|
|
- return result;
|
|
|
- }
|
|
|
-
|
|
|
public async Task<ItemUpdateType> RefreshMetadata(IHasMetadata item, MetadataRefreshOptions refreshOptions, CancellationToken cancellationToken)
|
|
|
{
|
|
|
var itemOfType = (TItemType)item;
|
|
|
var config = ProviderManager.GetMetadataOptions(item);
|
|
|
|
|
|
var updateType = ItemUpdateType.None;
|
|
|
- var refreshResult = GetLastResult(item);
|
|
|
|
|
|
var itemImageProvider = new ItemImageProvider(Logger, ProviderManager, ServerConfigurationManager, FileSystem);
|
|
|
var localImagesFailed = false;
|
|
@@ -153,12 +78,10 @@ namespace MediaBrowser.Providers.Manager
|
|
|
// TODO: If this returns true, should we instead just change metadata refresh mode to Full?
|
|
|
requiresRefresh = item.RequiresRefresh();
|
|
|
|
|
|
- var providers = GetProviders(item, refreshResult, refreshOptions, requiresRefresh)
|
|
|
+ var providers = GetProviders(item, refreshOptions, requiresRefresh)
|
|
|
.ToList();
|
|
|
|
|
|
- var dateLastRefresh = EnableDateLastRefreshed(item)
|
|
|
- ? item.DateLastRefreshed
|
|
|
- : refreshResult.DateLastMetadataRefresh ?? default(DateTime);
|
|
|
+ var dateLastRefresh = item.DateLastRefreshed;
|
|
|
|
|
|
if (providers.Count > 0 || dateLastRefresh == default(DateTime))
|
|
|
{
|
|
@@ -185,13 +108,11 @@ namespace MediaBrowser.Providers.Manager
|
|
|
updateType = updateType | result.UpdateType;
|
|
|
if (result.Failures == 0)
|
|
|
{
|
|
|
- refreshResult.SetDateLastMetadataRefresh(DateTime.UtcNow);
|
|
|
hasRefreshedMetadata = true;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
hasRefreshedMetadata = false;
|
|
|
- refreshResult.SetDateLastMetadataRefresh(null);
|
|
|
}
|
|
|
}
|
|
|
}
|
|
@@ -199,7 +120,7 @@ namespace MediaBrowser.Providers.Manager
|
|
|
// Next run remote image providers, but only if local image providers didn't throw an exception
|
|
|
if (!localImagesFailed && refreshOptions.ImageRefreshMode != ImageRefreshMode.ValidationOnly)
|
|
|
{
|
|
|
- var providers = GetNonLocalImageProviders(item, allImageProviders, refreshResult, refreshOptions).ToList();
|
|
|
+ var providers = GetNonLocalImageProviders(item, allImageProviders, refreshOptions).ToList();
|
|
|
|
|
|
if (providers.Count > 0)
|
|
|
{
|
|
@@ -208,13 +129,11 @@ namespace MediaBrowser.Providers.Manager
|
|
|
updateType = updateType | result.UpdateType;
|
|
|
if (result.Failures == 0)
|
|
|
{
|
|
|
- refreshResult.SetDateLastImagesRefresh(DateTime.UtcNow);
|
|
|
hasRefreshedImages = true;
|
|
|
}
|
|
|
else
|
|
|
{
|
|
|
hasRefreshedImages = false;
|
|
|
- refreshResult.SetDateLastImagesRefresh(null);
|
|
|
}
|
|
|
}
|
|
|
}
|
|
@@ -248,11 +167,6 @@ namespace MediaBrowser.Providers.Manager
|
|
|
await SaveItem(metadataResult, updateType, cancellationToken).ConfigureAwait(false);
|
|
|
}
|
|
|
|
|
|
- if (updateType > ItemUpdateType.None || refreshResult.IsDirty)
|
|
|
- {
|
|
|
- await SaveProviderResult(itemOfType, refreshResult, refreshOptions.DirectoryService).ConfigureAwait(false);
|
|
|
- }
|
|
|
-
|
|
|
await AfterMetadataRefresh(itemOfType, refreshOptions, cancellationToken).ConfigureAwait(false);
|
|
|
|
|
|
return updateType;
|
|
@@ -279,47 +193,7 @@ namespace MediaBrowser.Providers.Manager
|
|
|
|
|
|
private DateTime GetLastRefreshDate(IHasMetadata item)
|
|
|
{
|
|
|
- if (EnableDateLastRefreshed(item))
|
|
|
- {
|
|
|
- return item.DateLastRefreshed;
|
|
|
- }
|
|
|
-
|
|
|
- return item.DateLastSaved;
|
|
|
- }
|
|
|
-
|
|
|
- private bool EnableDateLastRefreshed(IHasMetadata item)
|
|
|
- {
|
|
|
- if (ServerConfigurationManager.Configuration.EnableDateLastRefresh)
|
|
|
- {
|
|
|
- return true;
|
|
|
- }
|
|
|
-
|
|
|
- if (item.DateLastRefreshed != default(DateTime))
|
|
|
- {
|
|
|
- return true;
|
|
|
- }
|
|
|
-
|
|
|
- if (!(item is Audio) && !(item is Video))
|
|
|
- {
|
|
|
- return true;
|
|
|
- }
|
|
|
-
|
|
|
- if (item is IItemByName)
|
|
|
- {
|
|
|
- return true;
|
|
|
- }
|
|
|
-
|
|
|
- if (item.SourceType != SourceType.Library)
|
|
|
- {
|
|
|
- return true;
|
|
|
- }
|
|
|
-
|
|
|
- if (item is MusicVideo)
|
|
|
- {
|
|
|
- return true;
|
|
|
- }
|
|
|
-
|
|
|
- return false;
|
|
|
+ return item.DateLastRefreshed;
|
|
|
}
|
|
|
|
|
|
protected async Task SaveItem(MetadataResult<TItemType> result, ItemUpdateType reason, CancellationToken cancellationToken)
|
|
@@ -466,14 +340,12 @@ namespace MediaBrowser.Providers.Manager
|
|
|
/// Gets the providers.
|
|
|
/// </summary>
|
|
|
/// <returns>IEnumerable{`0}.</returns>
|
|
|
- protected IEnumerable<IMetadataProvider> GetProviders(IHasMetadata item, MetadataStatus status, MetadataRefreshOptions options, bool requiresRefresh)
|
|
|
+ protected IEnumerable<IMetadataProvider> GetProviders(IHasMetadata item, MetadataRefreshOptions options, bool requiresRefresh)
|
|
|
{
|
|
|
// Get providers to refresh
|
|
|
var providers = ((ProviderManager)ProviderManager).GetMetadataProviders<TItemType>(item).ToList();
|
|
|
|
|
|
- var dateLastRefresh = EnableDateLastRefreshed(item)
|
|
|
- ? item.DateLastRefreshed
|
|
|
- : status.DateLastMetadataRefresh ?? default(DateTime);
|
|
|
+ var dateLastRefresh = item.DateLastRefreshed;
|
|
|
|
|
|
// Run all if either of these flags are true
|
|
|
var runAllProviders = options.ReplaceAllMetadata || options.MetadataRefreshMode == MetadataRefreshMode.FullRefresh || dateLastRefresh == default(DateTime) || requiresRefresh;
|
|
@@ -535,14 +407,12 @@ namespace MediaBrowser.Providers.Manager
|
|
|
return providers;
|
|
|
}
|
|
|
|
|
|
- protected virtual IEnumerable<IImageProvider> GetNonLocalImageProviders(IHasMetadata item, IEnumerable<IImageProvider> allImageProviders, MetadataStatus status, ImageRefreshOptions options)
|
|
|
+ protected virtual IEnumerable<IImageProvider> GetNonLocalImageProviders(IHasMetadata item, IEnumerable<IImageProvider> allImageProviders, ImageRefreshOptions options)
|
|
|
{
|
|
|
// Get providers to refresh
|
|
|
var providers = allImageProviders.Where(i => !(i is ILocalImageProvider)).ToList();
|
|
|
|
|
|
- var dateLastImageRefresh = EnableDateLastRefreshed(item)
|
|
|
- ? item.DateLastRefreshed
|
|
|
- : status.DateLastImagesRefresh ?? default(DateTime);
|
|
|
+ var dateLastImageRefresh = item.DateLastRefreshed;
|
|
|
|
|
|
// Run all if either of these flags are true
|
|
|
var runAllProviders = options.ImageRefreshMode == ImageRefreshMode.FullRefresh || dateLastImageRefresh == default(DateTime);
|