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

273 lines
8.2 KiB
C#
Raw Normal View History

2014-06-02 19:01:30 -07:00
using MediaBrowser.Controller.Persistence;
using MediaBrowser.Controller.Providers;
2014-02-06 20:10:13 -07:00
using MediaBrowser.Model.Configuration;
2014-06-02 19:01:30 -07:00
using MediaBrowser.Model.Dto;
using MediaBrowser.Model.Entities;
using MediaBrowser.Model.MediaInfo;
2015-01-28 14:29:02 -07:00
using MediaBrowser.Model.Users;
2013-12-26 09:53:23 -07:00
using System;
2013-02-20 18:33:05 -07:00
using System.Collections.Generic;
using System.Linq;
2013-02-20 18:33:05 -07:00
using System.Runtime.Serialization;
namespace MediaBrowser.Controller.Entities.Audio
{
/// <summary>
/// Class Audio
/// </summary>
public class Audio : BaseItem,
IHasAlbumArtist,
IHasArtist,
IHasMusicGenres,
IHasLookupInfo<SongInfo>,
2014-06-02 19:01:30 -07:00
IHasTags,
2014-08-25 19:30:52 -07:00
IHasMediaSources,
IThemeMedia
2013-02-20 18:33:05 -07:00
{
2014-04-17 22:03:01 -07:00
public string FormatName { get; set; }
public long? Size { get; set; }
public string Container { get; set; }
2014-04-22 10:25:54 -07:00
public int? TotalBitrate { get; set; }
2014-05-18 12:58:42 -07:00
public List<string> Tags { get; set; }
2014-09-22 14:56:54 -07:00
public ExtraType ExtraType { get; set; }
2014-04-17 22:03:01 -07:00
2014-08-25 19:30:52 -07:00
public bool IsThemeMedia { get; set; }
public Audio()
{
Artists = new List<string>();
AlbumArtists = new List<string>();
2014-05-18 12:58:42 -07:00
Tags = new List<string>();
}
2014-08-30 07:26:29 -07:00
[IgnoreDataMember]
public override bool SupportsAddingToPlaylist
{
get { return LocationType == LocationType.FileSystem && RunTimeTicks.HasValue; }
}
2013-02-20 18:33:05 -07:00
/// <summary>
2013-12-05 20:39:44 -07:00
/// Gets or sets a value indicating whether this instance has embedded image.
2013-02-20 18:33:05 -07:00
/// </summary>
2013-12-05 20:39:44 -07:00
/// <value><c>true</c> if this instance has embedded image; otherwise, <c>false</c>.</value>
public bool HasEmbeddedImage { get; set; }
2014-01-31 23:18:16 -07:00
2013-02-20 18:33:05 -07:00
/// <summary>
/// Override this to true if class should be grouped under a container in indicies
/// The container class should be defined via IndexContainer
/// </summary>
/// <value><c>true</c> if [group in index]; otherwise, <c>false</c>.</value>
[IgnoreDataMember]
public override bool GroupInIndex
{
get
{
return true;
}
}
/// <summary>
/// Override this to return the folder that should be used to construct a container
/// for this item in an index. GroupInIndex should be true as well.
/// </summary>
/// <value>The index container.</value>
[IgnoreDataMember]
public override Folder IndexContainer
{
get
{
return LatestItemsIndexContainer ?? new MusicAlbum { Name = "Unknown Album" };
}
}
2015-01-28 14:29:02 -07:00
[IgnoreDataMember]
protected override bool SupportsOwnedItems
{
get
{
return false;
}
}
2014-08-28 21:06:30 -07:00
[IgnoreDataMember]
public override Folder LatestItemsIndexContainer
{
get
{
return Parents.OfType<MusicAlbum>().FirstOrDefault();
2013-02-20 18:33:05 -07:00
}
}
2014-12-29 13:18:48 -07:00
[IgnoreDataMember]
public bool IsArchive
{
get
{
if (string.IsNullOrWhiteSpace(Path))
{
return false;
}
var ext = System.IO.Path.GetExtension(Path) ?? string.Empty;
return new[] { ".zip", ".rar", ".7z" }.Contains(ext, StringComparer.OrdinalIgnoreCase);
}
}
2015-02-05 22:39:07 -07:00
public override bool CanDownload()
{
var locationType = LocationType;
return locationType != LocationType.Remote &&
locationType != LocationType.Virtual;
}
2013-02-20 18:33:05 -07:00
/// <summary>
/// Gets or sets the artist.
/// </summary>
/// <value>The artist.</value>
public List<string> Artists { get; set; }
public List<string> AlbumArtists { get; set; }
[IgnoreDataMember]
public List<string> AllArtists
2014-06-23 09:05:19 -07:00
{
get
{
var list = AlbumArtists.ToList();
2014-06-23 09:05:19 -07:00
list.AddRange(Artists);
return list;
}
}
2013-02-20 18:33:05 -07:00
/// <summary>
/// Gets or sets the album.
/// </summary>
/// <value>The album.</value>
public string Album { get; set; }
/// <summary>
/// Gets the type of the media.
/// </summary>
/// <value>The type of the media.</value>
2014-08-30 07:26:29 -07:00
[IgnoreDataMember]
2013-02-20 18:33:05 -07:00
public override string MediaType
{
get
{
return Model.Entities.MediaType.Audio;
}
}
/// <summary>
/// Creates the name of the sort.
/// </summary>
/// <returns>System.String.</returns>
protected override string CreateSortName()
{
2013-04-22 20:56:11 -07:00
return (ParentIndexNumber != null ? ParentIndexNumber.Value.ToString("0000 - ") : "")
+ (IndexNumber != null ? IndexNumber.Value.ToString("0000 - ") : "") + Name;
}
2013-04-21 21:38:03 -07:00
/// <summary>
/// Determines whether the specified name has artist.
/// </summary>
/// <param name="name">The name.</param>
/// <returns><c>true</c> if the specified name has artist; otherwise, <c>false</c>.</returns>
public bool HasArtist(string name)
{
2014-06-23 09:05:19 -07:00
return AllArtists.Contains(name, StringComparer.OrdinalIgnoreCase);
2013-04-21 21:38:03 -07:00
}
/// <summary>
/// Gets the user data key.
/// </summary>
/// <returns>System.String.</returns>
2015-01-24 15:33:26 -07:00
protected override string CreateUserDataKey()
{
2014-01-11 23:31:21 -07:00
var parent = FindParent<MusicAlbum>();
if (parent != null)
{
var parentKey = parent.GetUserDataKey();
if (IndexNumber.HasValue)
{
var songKey = (ParentIndexNumber != null ? ParentIndexNumber.Value.ToString("0000 - ") : "")
+ (IndexNumber.Value.ToString("0000 - "));
return parentKey + songKey;
}
}
2015-01-24 15:33:26 -07:00
return base.CreateUserDataKey();
}
2013-12-26 09:53:23 -07:00
2014-12-19 23:06:27 -07:00
protected override bool GetBlockUnratedValue(UserPolicy config)
2013-12-26 09:53:23 -07:00
{
return config.BlockUnratedItems.Contains(UnratedItem.Music);
2013-12-26 09:53:23 -07:00
}
2014-02-06 20:10:13 -07:00
public SongInfo GetLookupInfo()
{
var info = GetItemLookupInfo<SongInfo>();
2014-06-23 09:05:19 -07:00
info.AlbumArtists = AlbumArtists;
2014-02-06 20:10:13 -07:00
info.Album = Album;
info.Artists = Artists;
return info;
}
2014-06-02 19:01:30 -07:00
public virtual IEnumerable<MediaSourceInfo> GetMediaSources(bool enablePathSubstitution)
{
var result = new List<MediaSourceInfo>
{
GetVersionInfo(this, enablePathSubstitution)
};
return result;
}
private static MediaSourceInfo GetVersionInfo(Audio i, bool enablePathSubstituion)
{
var locationType = i.LocationType;
2014-06-02 19:01:30 -07:00
var info = new MediaSourceInfo
{
Id = i.Id.ToString("N"),
Protocol = locationType == LocationType.Remote ? MediaProtocol.Http : MediaProtocol.File,
MediaStreams = MediaSourceManager.GetMediaStreams(new MediaStreamQuery { ItemId = i.Id }).ToList(),
2014-06-02 19:01:30 -07:00
Name = i.Name,
Path = enablePathSubstituion ? GetMappedPath(i.Path, locationType) : i.Path,
RunTimeTicks = i.RunTimeTicks,
Container = i.Container,
Size = i.Size,
Formats = (i.FormatName ?? string.Empty).Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries).ToList()
};
if (string.IsNullOrEmpty(info.Container))
{
if (!string.IsNullOrWhiteSpace(i.Path) && locationType != LocationType.Remote && locationType != LocationType.Virtual)
{
info.Container = System.IO.Path.GetExtension(i.Path).TrimStart('.');
}
}
var bitrate = i.TotalBitrate ??
info.MediaStreams.Where(m => m.Type == MediaStreamType.Audio)
.Select(m => m.BitRate ?? 0)
.Sum();
if (bitrate > 0)
{
info.Bitrate = bitrate;
}
return info;
}
2013-02-20 18:33:05 -07:00
}
}