jellyfin/MediaBrowser.Controller/Entities/Audio/MusicArtist.cs

225 lines
6.8 KiB
C#
Raw Normal View History

using System;
2018-12-27 16:27:57 -07:00
using System.Collections.Generic;
using System.Linq;
2019-10-15 08:49:49 -07:00
using System.Text.Json.Serialization;
2018-12-27 16:27:57 -07:00
using System.Threading;
using System.Threading.Tasks;
2020-05-20 10:07:53 -07:00
using Jellyfin.Data.Entities;
2020-05-12 19:10:35 -07:00
using Jellyfin.Data.Enums;
2018-12-27 16:27:57 -07:00
using MediaBrowser.Controller.Extensions;
using MediaBrowser.Controller.Providers;
using MediaBrowser.Model.Entities;
2018-12-27 17:11:04 -07:00
using Microsoft.Extensions.Logging;
2020-06-11 15:28:49 -07:00
using MetadataProvider = MediaBrowser.Model.Entities.MetadataProvider;
2018-12-27 16:27:57 -07:00
namespace MediaBrowser.Controller.Entities.Audio
{
/// <summary>
/// Class MusicArtist.
2018-12-27 16:27:57 -07:00
/// </summary>
public class MusicArtist : Folder, IItemByName, IHasMusicGenres, IHasDualAccess, IHasLookupInfo<ArtistInfo>
{
2019-10-15 08:49:49 -07:00
[JsonIgnore]
public bool IsAccessedByName => ParentId.Equals(Guid.Empty);
2018-12-27 16:27:57 -07:00
2019-10-15 08:49:49 -07:00
[JsonIgnore]
public override bool IsFolder => !IsAccessedByName;
2018-12-27 16:27:57 -07:00
2019-10-15 08:49:49 -07:00
[JsonIgnore]
public override bool SupportsInheritedParentImages => false;
2018-12-27 16:27:57 -07:00
2019-10-15 08:49:49 -07:00
[JsonIgnore]
public override bool SupportsCumulativeRunTimeTicks => true;
2018-12-27 16:27:57 -07:00
2019-10-15 08:49:49 -07:00
[JsonIgnore]
public override bool IsDisplayedAsFolder => true;
2018-12-27 16:27:57 -07:00
2019-10-15 08:49:49 -07:00
[JsonIgnore]
public override bool SupportsAddingToPlaylist => true;
2018-12-27 16:27:57 -07:00
2019-10-15 08:49:49 -07:00
[JsonIgnore]
public override bool SupportsPlayedStatus => false;
2018-12-27 16:27:57 -07:00
public override double GetDefaultPrimaryImageAspectRatio()
{
return 1;
}
public override bool CanDelete()
{
return !IsAccessedByName;
}
public IList<BaseItem> GetTaggedItems(InternalItemsQuery query)
{
if (query.IncludeItemTypes.Length == 0)
{
query.IncludeItemTypes = new[] { typeof(Audio).Name, typeof(MusicVideo).Name, typeof(MusicAlbum).Name };
query.ArtistIds = new[] { Id };
}
return LibraryManager.GetItemList(query);
}
2019-10-15 08:49:49 -07:00
[JsonIgnore]
2018-12-27 16:27:57 -07:00
public override IEnumerable<BaseItem> Children
{
get
{
if (IsAccessedByName)
{
return new List<BaseItem>();
}
return base.Children;
}
}
2020-05-20 10:07:53 -07:00
public override int GetChildCount(User user)
2018-12-27 16:27:57 -07:00
{
2020-05-20 10:07:53 -07:00
return IsAccessedByName ? 0 : base.GetChildCount(user);
2018-12-27 16:27:57 -07:00
}
public override bool IsSaveLocalMetadataEnabled()
{
if (IsAccessedByName)
{
return true;
}
return base.IsSaveLocalMetadataEnabled();
}
protected override Task ValidateChildrenInternal(IProgress<double> progress, CancellationToken cancellationToken, bool recursive, bool refreshChildMetadata, MetadataRefreshOptions refreshOptions, IDirectoryService directoryService)
{
if (IsAccessedByName)
{
// Should never get in here anyway
2018-12-27 14:43:48 -07:00
return Task.CompletedTask;
2018-12-27 16:27:57 -07:00
}
return base.ValidateChildrenInternal(progress, cancellationToken, recursive, refreshChildMetadata, refreshOptions, directoryService);
}
public override List<string> GetUserDataKeys()
{
var list = base.GetUserDataKeys();
list.InsertRange(0, GetUserDataKeys(this));
return list;
}
/// <summary>
/// Returns the folder containing the item.
/// If the item is a folder, it returns the folder itself.
2018-12-27 16:27:57 -07:00
/// </summary>
/// <value>The containing folder path.</value>
2019-10-15 08:49:49 -07:00
[JsonIgnore]
public override string ContainingFolderPath => Path;
2018-12-27 16:27:57 -07:00
/// <summary>
/// Gets the user data key.
/// </summary>
/// <param name="item">The item.</param>
/// <returns>System.String.</returns>
private static List<string> GetUserDataKeys(MusicArtist item)
{
var list = new List<string>();
2020-06-06 12:17:49 -07:00
var id = item.GetProviderId(MetadataProvider.MusicBrainzArtist);
2018-12-27 16:27:57 -07:00
if (!string.IsNullOrEmpty(id))
{
list.Add("Artist-Musicbrainz-" + id);
}
list.Add("Artist-" + (item.Name ?? string.Empty).RemoveDiacritics());
return list;
}
2020-06-15 14:43:52 -07:00
2018-12-27 16:27:57 -07:00
public override string CreatePresentationUniqueKey()
{
return "Artist-" + (Name ?? string.Empty).RemoveDiacritics();
}
2020-05-12 19:10:35 -07:00
2020-05-20 10:07:53 -07:00
protected override bool GetBlockUnratedValue(User user)
2018-12-27 16:27:57 -07:00
{
2020-05-12 19:10:35 -07:00
return user.GetPreference(PreferenceKind.BlockUnratedItems).Contains(UnratedItem.Music.ToString());
2018-12-27 16:27:57 -07:00
}
public override UnratedItem GetBlockUnratedType()
{
return UnratedItem.Music;
}
public ArtistInfo GetLookupInfo()
{
var info = GetItemLookupInfo<ArtistInfo>();
info.SongInfos = GetRecursiveChildren(i => i is Audio)
.Cast<Audio>()
.Select(i => i.GetLookupInfo())
.ToList();
return info;
}
2019-10-15 08:49:49 -07:00
[JsonIgnore]
public override bool SupportsPeople => false;
2018-12-27 16:27:57 -07:00
public static string GetPath(string name)
{
return GetPath(name, true);
}
public static string GetPath(string name, bool normalizeName)
{
// Trim the period at the end because windows will have a hard time with that
var validName = normalizeName ?
FileSystem.GetValidFilename(name).Trim().TrimEnd('.') :
name;
return System.IO.Path.Combine(ConfigurationManager.ApplicationPaths.ArtistsPath, validName);
}
private string GetRebasedPath()
{
return GetPath(System.IO.Path.GetFileName(Path), false);
}
public override bool RequiresRefresh()
{
if (IsAccessedByName)
{
var newPath = GetRebasedPath();
if (!string.Equals(Path, newPath, StringComparison.Ordinal))
{
2018-12-27 17:11:04 -07:00
Logger.LogDebug("{0} path has changed from {1} to {2}", GetType().Name, Path, newPath);
2018-12-27 16:27:57 -07:00
return true;
}
}
2020-02-21 23:04:52 -07:00
2018-12-27 16:27:57 -07:00
return base.RequiresRefresh();
}
/// <summary>
/// This is called before any metadata refresh and returns true or false indicating if changes were made.
2018-12-27 16:27:57 -07:00
/// </summary>
public override bool BeforeMetadataRefresh(bool replaceAllMetdata)
{
var hasChanges = base.BeforeMetadataRefresh(replaceAllMetdata);
if (IsAccessedByName)
{
var newPath = GetRebasedPath();
if (!string.Equals(Path, newPath, StringComparison.Ordinal))
{
Path = newPath;
hasChanges = true;
}
}
return hasChanges;
}
}
}