aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Controller/Playlists/Playlist.cs
diff options
context:
space:
mode:
authorstefan <stefan@hegedues.at>2018-09-12 19:26:21 +0200
committerstefan <stefan@hegedues.at>2018-09-12 19:26:21 +0200
commit48facb797ed912e4ea6b04b17d1ff190ac2daac4 (patch)
tree8dae77a31670a888d733484cb17dd4077d5444e8 /MediaBrowser.Controller/Playlists/Playlist.cs
parentc32d8656382a0eacb301692e0084377fc433ae9b (diff)
Update to 3.5.2 and .net core 2.1
Diffstat (limited to 'MediaBrowser.Controller/Playlists/Playlist.cs')
-rw-r--r--MediaBrowser.Controller/Playlists/Playlist.cs227
1 files changed, 0 insertions, 227 deletions
diff --git a/MediaBrowser.Controller/Playlists/Playlist.cs b/MediaBrowser.Controller/Playlists/Playlist.cs
deleted file mode 100644
index 071f8a0961..0000000000
--- a/MediaBrowser.Controller/Playlists/Playlist.cs
+++ /dev/null
@@ -1,227 +0,0 @@
-using MediaBrowser.Controller.Entities;
-using MediaBrowser.Controller.Entities.Audio;
-using MediaBrowser.Model.Entities;
-using MediaBrowser.Model.Querying;
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using MediaBrowser.Model.Serialization;
-using System.Threading.Tasks;
-using MediaBrowser.Controller.Dto;
-using MediaBrowser.Controller.Providers;
-
-namespace MediaBrowser.Controller.Playlists
-{
- public class Playlist : Folder, IHasShares
- {
- public string OwnerUserId { get; set; }
-
- public List<Share> Shares { get; set; }
-
- public Playlist()
- {
- Shares = new List<Share>();
- }
-
- [IgnoreDataMember]
- protected override bool FilterLinkedChildrenPerUser
- {
- get
- {
- return true;
- }
- }
-
- [IgnoreDataMember]
- public override bool SupportsInheritedParentImages
- {
- get
- {
- return false;
- }
- }
-
- [IgnoreDataMember]
- public override bool SupportsPlayedStatus
- {
- get
- {
- return string.Equals(MediaType, "Video", StringComparison.OrdinalIgnoreCase);
- }
- }
-
- [IgnoreDataMember]
- public override bool AlwaysScanInternalMetadataPath
- {
- get
- {
- return true;
- }
- }
-
- [IgnoreDataMember]
- public override bool SupportsCumulativeRunTimeTicks
- {
- get
- {
- return true;
- }
- }
-
- public override double? GetDefaultPrimaryImageAspectRatio()
- {
- return 1;
- }
-
- public override bool IsAuthorizedToDelete(User user, List<Folder> allCollectionFolders)
- {
- return true;
- }
-
- public override bool IsSaveLocalMetadataEnabled()
- {
- return true;
- }
-
- protected override List<BaseItem> LoadChildren()
- {
- // Save a trip to the database
- return new List<BaseItem>();
- }
-
- public override List<BaseItem> GetChildren(User user, bool includeLinkedChildren)
- {
- return GetPlayableItems(user, new DtoOptions(true));
- }
-
- protected override IEnumerable<BaseItem> GetNonCachedChildren(IDirectoryService directoryService)
- {
- return new List<BaseItem>();
- }
-
- public override IEnumerable<BaseItem> GetRecursiveChildren(User user, InternalItemsQuery query)
- {
- var items = GetPlayableItems(user, query.DtoOptions);
-
- if (query != null)
- {
- items = items.Where(i => UserViewBuilder.FilterItem(i, query)).ToList();
- }
-
- return items;
- }
-
- public IEnumerable<Tuple<LinkedChild, BaseItem>> GetManageableItems()
- {
- return GetLinkedChildrenInfos();
- }
-
- private List<BaseItem> GetPlayableItems(User user, DtoOptions options)
- {
- return GetPlaylistItems(MediaType, base.GetChildren(user, true), user, options);
- }
-
- public static List<BaseItem> GetPlaylistItems(string playlistMediaType, IEnumerable<BaseItem> inputItems, User user, DtoOptions options)
- {
- if (user != null)
- {
- inputItems = inputItems.Where(i => i.IsVisible(user));
- }
-
- var list = new List<BaseItem>();
-
- foreach (var item in inputItems)
- {
- var playlistItems = GetPlaylistItems(item, user, playlistMediaType, options);
- list.AddRange(playlistItems);
- }
-
- return list;
- }
-
- private static IEnumerable<BaseItem> GetPlaylistItems(BaseItem item, User user, string mediaType, DtoOptions options)
- {
- var musicGenre = item as MusicGenre;
- if (musicGenre != null)
- {
- return LibraryManager.GetItemList(new InternalItemsQuery(user)
- {
- Recursive = true,
- IncludeItemTypes = new[] { typeof(Audio).Name },
- GenreIds = new[] { musicGenre.Id.ToString("N") },
- OrderBy = new[] { ItemSortBy.AlbumArtist, ItemSortBy.Album, ItemSortBy.SortName }.Select(i => new Tuple<string, SortOrder>(i, SortOrder.Ascending)).ToArray(),
- DtoOptions = options
- });
- }
-
- var musicArtist = item as MusicArtist;
- if (musicArtist != null)
- {
- return LibraryManager.GetItemList(new InternalItemsQuery(user)
- {
- Recursive = true,
- IncludeItemTypes = new[] { typeof(Audio).Name },
- ArtistIds = new[] { musicArtist.Id.ToString("N") },
- OrderBy = new[] { ItemSortBy.AlbumArtist, ItemSortBy.Album, ItemSortBy.SortName }.Select(i => new Tuple<string, SortOrder>(i, SortOrder.Ascending)).ToArray(),
- DtoOptions = options
- });
- }
-
- var folder = item as Folder;
- if (folder != null)
- {
- var query = new InternalItemsQuery(user)
- {
- Recursive = true,
- IsFolder = false,
- OrderBy = new[] { ItemSortBy.SortName }.Select(i => new Tuple<string, SortOrder>(i, SortOrder.Ascending)).ToArray(),
- MediaTypes = new[] { mediaType },
- EnableTotalRecordCount = false,
- DtoOptions = options
- };
-
- return folder.GetItemList(query);
- }
-
- return new[] { item };
- }
-
- [IgnoreDataMember]
- public override bool IsPreSorted
- {
- get
- {
- return true;
- }
- }
-
- public string PlaylistMediaType { get; set; }
-
- [IgnoreDataMember]
- public override string MediaType
- {
- get
- {
- return PlaylistMediaType;
- }
- }
-
- public void SetMediaType(string value)
- {
- PlaylistMediaType = value;
- }
-
- public override bool IsVisible(User user)
- {
- var userId = user.Id.ToString("N");
-
- return Shares.Any(i => string.Equals(userId, i.UserId, StringComparison.OrdinalIgnoreCase)) ||
- string.Equals(OwnerUserId, userId, StringComparison.OrdinalIgnoreCase);
- }
-
- public override bool IsVisibleStandalone(User user)
- {
- return IsVisible(user);
- }
- }
-}