|
@@ -0,0 +1,107 @@
|
|
|
+using MediaBrowser.Controller.Configuration;
|
|
|
+using MediaBrowser.Controller.Entities;
|
|
|
+using MediaBrowser.Controller.Entities.Audio;
|
|
|
+using MediaBrowser.Controller.Providers;
|
|
|
+using MediaBrowser.Model.Entities;
|
|
|
+using MediaBrowser.Model.Logging;
|
|
|
+using System;
|
|
|
+using System.IO;
|
|
|
+using System.Threading;
|
|
|
+using System.Threading.Tasks;
|
|
|
+
|
|
|
+namespace MediaBrowser.Providers.Music
|
|
|
+{
|
|
|
+ class ArtistProviderFromXml : BaseMetadataProvider
|
|
|
+ {
|
|
|
+ public ArtistProviderFromXml(ILogManager logManager, IServerConfigurationManager configurationManager)
|
|
|
+ : base(logManager, configurationManager)
|
|
|
+ {
|
|
|
+ }
|
|
|
+
|
|
|
+ /// <summary>
|
|
|
+ /// Supportses the specified item.
|
|
|
+ /// </summary>
|
|
|
+ /// <param name="item">The item.</param>
|
|
|
+ /// <returns><c>true</c> if XXXX, <c>false</c> otherwise</returns>
|
|
|
+ public override bool Supports(BaseItem item)
|
|
|
+ {
|
|
|
+ return (item is Artist || item is MusicArtist) && item.LocationType == LocationType.FileSystem;
|
|
|
+ }
|
|
|
+
|
|
|
+ /// <summary>
|
|
|
+ /// Gets the priority.
|
|
|
+ /// </summary>
|
|
|
+ /// <value>The priority.</value>
|
|
|
+ public override MetadataProviderPriority Priority
|
|
|
+ {
|
|
|
+ get { return MetadataProviderPriority.First; }
|
|
|
+ }
|
|
|
+
|
|
|
+ /// <summary>
|
|
|
+ /// Override this to return the date that should be compared to the last refresh date
|
|
|
+ /// to determine if this provider should be re-fetched.
|
|
|
+ /// </summary>
|
|
|
+ /// <param name="item">The item.</param>
|
|
|
+ /// <returns>DateTime.</returns>
|
|
|
+ protected override DateTime CompareDate(BaseItem item)
|
|
|
+ {
|
|
|
+ var entry = item.MetaLocation != null ? item.ResolveArgs.GetMetaFileByPath(Path.Combine(item.MetaLocation, "artist.xml")) : null;
|
|
|
+ return entry != null ? entry.LastWriteTimeUtc : DateTime.MinValue;
|
|
|
+ }
|
|
|
+
|
|
|
+ /// <summary>
|
|
|
+ /// Fetches metadata and returns true or false indicating if any work that requires persistence was done
|
|
|
+ /// </summary>
|
|
|
+ /// <param name="item">The item.</param>
|
|
|
+ /// <param name="force">if set to <c>true</c> [force].</param>
|
|
|
+ /// <param name="cancellationToken">The cancellation token.</param>
|
|
|
+ /// <returns>Task{System.Boolean}.</returns>
|
|
|
+ public override Task<bool> FetchAsync(BaseItem item, bool force, CancellationToken cancellationToken)
|
|
|
+ {
|
|
|
+ return Fetch(item, cancellationToken);
|
|
|
+ }
|
|
|
+
|
|
|
+ /// <summary>
|
|
|
+ /// Fetches the specified item.
|
|
|
+ /// </summary>
|
|
|
+ /// <param name="item">The item.</param>
|
|
|
+ /// <param name="cancellationToken">The cancellation token.</param>
|
|
|
+ /// <returns><c>true</c> if XXXX, <c>false</c> otherwise</returns>
|
|
|
+ private async Task<bool> Fetch(BaseItem item, CancellationToken cancellationToken)
|
|
|
+ {
|
|
|
+ cancellationToken.ThrowIfCancellationRequested();
|
|
|
+
|
|
|
+ var metadataFile = item.ResolveArgs.GetMetaFileByPath(Path.Combine(item.MetaLocation, "artist.xml"));
|
|
|
+
|
|
|
+ if (metadataFile != null)
|
|
|
+ {
|
|
|
+ var path = metadataFile.FullName;
|
|
|
+
|
|
|
+ await XmlParsingResourcePool.WaitAsync(cancellationToken).ConfigureAwait(false);
|
|
|
+
|
|
|
+ try
|
|
|
+ {
|
|
|
+ var artist = item as Artist;
|
|
|
+
|
|
|
+ if (artist != null)
|
|
|
+ {
|
|
|
+ new BaseItemXmlParser<Artist>(Logger).Fetch(artist, path, cancellationToken);
|
|
|
+ }
|
|
|
+ else
|
|
|
+ {
|
|
|
+ new BaseItemXmlParser<MusicArtist>(Logger).Fetch((MusicArtist)item, path, cancellationToken);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ finally
|
|
|
+ {
|
|
|
+ XmlParsingResourcePool.Release();
|
|
|
+ }
|
|
|
+
|
|
|
+ SetLastRefreshed(item, DateTime.UtcNow);
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|