|
|
@ -27,6 +27,7 @@ using MediaBrowser.Controller.Dto;
|
|
|
|
using MediaBrowser.Controller.Entities.Audio;
|
|
|
|
using MediaBrowser.Controller.Entities.Audio;
|
|
|
|
using MediaBrowser.Controller.MediaEncoding;
|
|
|
|
using MediaBrowser.Controller.MediaEncoding;
|
|
|
|
using MediaBrowser.Controller.Playlists;
|
|
|
|
using MediaBrowser.Controller.Playlists;
|
|
|
|
|
|
|
|
using MediaBrowser.Controller.TV;
|
|
|
|
using MediaBrowser.Model.Globalization;
|
|
|
|
using MediaBrowser.Model.Globalization;
|
|
|
|
using MediaBrowser.Model.Xml;
|
|
|
|
using MediaBrowser.Model.Xml;
|
|
|
|
|
|
|
|
|
|
|
@ -40,6 +41,7 @@ namespace Emby.Dlna.ContentDirectory
|
|
|
|
private readonly IServerConfigurationManager _config;
|
|
|
|
private readonly IServerConfigurationManager _config;
|
|
|
|
private readonly User _user;
|
|
|
|
private readonly User _user;
|
|
|
|
private readonly IUserViewManager _userViewManager;
|
|
|
|
private readonly IUserViewManager _userViewManager;
|
|
|
|
|
|
|
|
private readonly ITVSeriesManager _tvSeriesManager;
|
|
|
|
|
|
|
|
|
|
|
|
private const string NS_DC = "http://purl.org/dc/elements/1.1/";
|
|
|
|
private const string NS_DC = "http://purl.org/dc/elements/1.1/";
|
|
|
|
private const string NS_DIDL = "urn:schemas-upnp-org:metadata-1-0/DIDL-Lite/";
|
|
|
|
private const string NS_DIDL = "urn:schemas-upnp-org:metadata-1-0/DIDL-Lite/";
|
|
|
@ -53,7 +55,7 @@ namespace Emby.Dlna.ContentDirectory
|
|
|
|
|
|
|
|
|
|
|
|
private readonly DeviceProfile _profile;
|
|
|
|
private readonly DeviceProfile _profile;
|
|
|
|
|
|
|
|
|
|
|
|
public ControlHandler(ILogger logger, ILibraryManager libraryManager, DeviceProfile profile, string serverAddress, string accessToken, IImageProcessor imageProcessor, IUserDataManager userDataManager, User user, int systemUpdateId, IServerConfigurationManager config, ILocalizationManager localization, IChannelManager channelManager, IMediaSourceManager mediaSourceManager, IUserViewManager userViewManager, IMediaEncoder mediaEncoder, IXmlReaderSettingsFactory xmlReaderSettingsFactory)
|
|
|
|
public ControlHandler(ILogger logger, ILibraryManager libraryManager, DeviceProfile profile, string serverAddress, string accessToken, IImageProcessor imageProcessor, IUserDataManager userDataManager, User user, int systemUpdateId, IServerConfigurationManager config, ILocalizationManager localization, IChannelManager channelManager, IMediaSourceManager mediaSourceManager, IUserViewManager userViewManager, IMediaEncoder mediaEncoder, IXmlReaderSettingsFactory xmlReaderSettingsFactory, ITVSeriesManager tvSeriesManager)
|
|
|
|
: base(config, logger, xmlReaderSettingsFactory)
|
|
|
|
: base(config, logger, xmlReaderSettingsFactory)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_libraryManager = libraryManager;
|
|
|
|
_libraryManager = libraryManager;
|
|
|
@ -62,6 +64,7 @@ namespace Emby.Dlna.ContentDirectory
|
|
|
|
_systemUpdateId = systemUpdateId;
|
|
|
|
_systemUpdateId = systemUpdateId;
|
|
|
|
_channelManager = channelManager;
|
|
|
|
_channelManager = channelManager;
|
|
|
|
_userViewManager = userViewManager;
|
|
|
|
_userViewManager = userViewManager;
|
|
|
|
|
|
|
|
_tvSeriesManager = tvSeriesManager;
|
|
|
|
_profile = profile;
|
|
|
|
_profile = profile;
|
|
|
|
_config = config;
|
|
|
|
_config = config;
|
|
|
|
|
|
|
|
|
|
|
@ -488,6 +491,14 @@ namespace Emby.Dlna.ContentDirectory
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return GetMusicFolders(item, user, stubType, sort, startIndex, limit);
|
|
|
|
return GetMusicFolders(item, user, stubType, sort, startIndex, limit);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (collectionFolder != null && string.Equals(CollectionType.Movies, collectionFolder.CollectionType, StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return GetMovieFolders(item, user, stubType, sort, startIndex, limit);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if (collectionFolder != null && string.Equals(CollectionType.TvShows, collectionFolder.CollectionType, StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return GetTvFolders(item, user, stubType, sort, startIndex, limit);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (stubType.HasValue)
|
|
|
|
if (stubType.HasValue)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -656,6 +667,231 @@ namespace Emby.Dlna.ContentDirectory
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<ServerItem> GetMovieFolders(BaseItem item, User user, StubType? stubType, SortCriteria sort, int? startIndex, int? limit)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
var query = new InternalItemsQuery(user)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
StartIndex = startIndex,
|
|
|
|
|
|
|
|
Limit = limit
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
SetSorting(query, sort, false);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (stubType.HasValue && stubType.Value == StubType.ContinueWatching)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return GetMovieContinueWatching(item, user, query);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (stubType.HasValue && stubType.Value == StubType.Latest)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return GetMovieLatest(item, user, query);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (stubType.HasValue && stubType.Value == StubType.Movies)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return GetMovieMovies(item, user, query);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (stubType.HasValue && stubType.Value == StubType.Collections)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return GetMovieCollections(item, user, query);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (stubType.HasValue && stubType.Value == StubType.Favorites)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return GetMovieFavorites(item, user, query);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (stubType.HasValue && stubType.Value == StubType.Genres)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return GetGenres(item, user, query);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var list = new List<ServerItem>();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
list.Add(new ServerItem(item)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
StubType = StubType.ContinueWatching
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
list.Add(new ServerItem(item)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
StubType = StubType.Latest
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
list.Add(new ServerItem(item)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
StubType = StubType.Movies
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
list.Add(new ServerItem(item)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
StubType = StubType.Collections
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
list.Add(new ServerItem(item)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
StubType = StubType.Favorites
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
list.Add(new ServerItem(item)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
StubType = StubType.Genres
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return new QueryResult<ServerItem>
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
Items = list.ToArray(),
|
|
|
|
|
|
|
|
TotalRecordCount = list.Count
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<ServerItem> GetTvFolders(BaseItem item, User user, StubType? stubType, SortCriteria sort, int? startIndex, int? limit)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
var query = new InternalItemsQuery(user)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
StartIndex = startIndex,
|
|
|
|
|
|
|
|
Limit = limit
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
SetSorting(query, sort, false);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (stubType.HasValue && stubType.Value == StubType.ContinueWatching)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return GetMovieContinueWatching(item, user, query);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (stubType.HasValue && stubType.Value == StubType.NextUp)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return GetNextUp(item, user, query);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (stubType.HasValue && stubType.Value == StubType.Latest)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return GetTvLatest(item, user, query);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (stubType.HasValue && stubType.Value == StubType.Series)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return GetSeries(item, user, query);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (stubType.HasValue && stubType.Value == StubType.FavoriteSeries)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return GetFavoriteSeries(item, user, query);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (stubType.HasValue && stubType.Value == StubType.FavoriteEpisodes)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return GetFavoriteEpisodes(item, user, query);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (stubType.HasValue && stubType.Value == StubType.Genres)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return GetGenres(item, user, query);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var list = new List<ServerItem>();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
list.Add(new ServerItem(item)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
StubType = StubType.ContinueWatching
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
list.Add(new ServerItem(item)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
StubType = StubType.NextUp
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
list.Add(new ServerItem(item)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
StubType = StubType.Latest
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
list.Add(new ServerItem(item)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
StubType = StubType.Series
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
list.Add(new ServerItem(item)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
StubType = StubType.FavoriteSeries
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
list.Add(new ServerItem(item)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
StubType = StubType.FavoriteEpisodes
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
list.Add(new ServerItem(item)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
StubType = StubType.Genres
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return new QueryResult<ServerItem>
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
Items = list.ToArray(),
|
|
|
|
|
|
|
|
TotalRecordCount = list.Count
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<ServerItem> GetMovieContinueWatching(BaseItem parent, User user, InternalItemsQuery query)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
query.Recursive = true;
|
|
|
|
|
|
|
|
query.Parent = parent;
|
|
|
|
|
|
|
|
query.SetUser(user);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
query.OrderBy = new List<Tuple<string, SortOrder>>
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
new Tuple<string, SortOrder> (ItemSortBy.DatePlayed, SortOrder.Descending),
|
|
|
|
|
|
|
|
new Tuple<string, SortOrder> (ItemSortBy.SortName, SortOrder.Ascending)
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
query.IsResumable = true;
|
|
|
|
|
|
|
|
query.Limit = 10;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var result = _libraryManager.GetItemsResult(query);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return ToResult(result);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<ServerItem> GetSeries(BaseItem parent, User user, InternalItemsQuery query)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
query.Recursive = true;
|
|
|
|
|
|
|
|
query.Parent = parent;
|
|
|
|
|
|
|
|
query.SetUser(user);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
query.IncludeItemTypes = new[] { typeof(Series).Name };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var result = _libraryManager.GetItemsResult(query);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return ToResult(result);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<ServerItem> GetMovieMovies(BaseItem parent, User user, InternalItemsQuery query)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
query.Recursive = true;
|
|
|
|
|
|
|
|
query.Parent = parent;
|
|
|
|
|
|
|
|
query.SetUser(user);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
query.IncludeItemTypes = new[] { typeof(Movie).Name };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var result = _libraryManager.GetItemsResult(query);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return ToResult(result);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<ServerItem> GetMovieCollections(BaseItem parent, User user, InternalItemsQuery query)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
query.Recursive = true;
|
|
|
|
|
|
|
|
//query.Parent = parent;
|
|
|
|
|
|
|
|
query.SetUser(user);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
query.IncludeItemTypes = new[] { typeof(BoxSet).Name };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var result = _libraryManager.GetItemsResult(query);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return ToResult(result);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<ServerItem> GetMusicAlbums(BaseItem parent, User user, InternalItemsQuery query)
|
|
|
|
private QueryResult<ServerItem> GetMusicAlbums(BaseItem parent, User user, InternalItemsQuery query)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
query.Recursive = true;
|
|
|
|
query.Recursive = true;
|
|
|
@ -695,6 +931,45 @@ namespace Emby.Dlna.ContentDirectory
|
|
|
|
return ToResult(result);
|
|
|
|
return ToResult(result);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<ServerItem> GetFavoriteSeries(BaseItem parent, User user, InternalItemsQuery query)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
query.Recursive = true;
|
|
|
|
|
|
|
|
query.Parent = parent;
|
|
|
|
|
|
|
|
query.SetUser(user);
|
|
|
|
|
|
|
|
query.IsFavorite = true;
|
|
|
|
|
|
|
|
query.IncludeItemTypes = new[] { typeof(Series).Name };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var result = _libraryManager.GetItemsResult(query);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return ToResult(result);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<ServerItem> GetFavoriteEpisodes(BaseItem parent, User user, InternalItemsQuery query)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
query.Recursive = true;
|
|
|
|
|
|
|
|
query.Parent = parent;
|
|
|
|
|
|
|
|
query.SetUser(user);
|
|
|
|
|
|
|
|
query.IsFavorite = true;
|
|
|
|
|
|
|
|
query.IncludeItemTypes = new[] { typeof(Episode).Name };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var result = _libraryManager.GetItemsResult(query);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return ToResult(result);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<ServerItem> GetMovieFavorites(BaseItem parent, User user, InternalItemsQuery query)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
query.Recursive = true;
|
|
|
|
|
|
|
|
query.Parent = parent;
|
|
|
|
|
|
|
|
query.SetUser(user);
|
|
|
|
|
|
|
|
query.IsFavorite = true;
|
|
|
|
|
|
|
|
query.IncludeItemTypes = new[] { typeof(Movie).Name };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var result = _libraryManager.GetItemsResult(query);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return ToResult(result);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<ServerItem> GetFavoriteAlbums(BaseItem parent, User user, InternalItemsQuery query)
|
|
|
|
private QueryResult<ServerItem> GetFavoriteAlbums(BaseItem parent, User user, InternalItemsQuery query)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
query.Recursive = true;
|
|
|
|
query.Recursive = true;
|
|
|
@ -708,6 +983,24 @@ namespace Emby.Dlna.ContentDirectory
|
|
|
|
return ToResult(result);
|
|
|
|
return ToResult(result);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<ServerItem> GetGenres(BaseItem parent, User user, InternalItemsQuery query)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
var genresResult = _libraryManager.GetGenres(new InternalItemsQuery(user)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
AncestorIds = new[] { parent.Id.ToString("N") },
|
|
|
|
|
|
|
|
StartIndex = query.StartIndex,
|
|
|
|
|
|
|
|
Limit = query.Limit
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var result = new QueryResult<BaseItem>
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
TotalRecordCount = genresResult.TotalRecordCount,
|
|
|
|
|
|
|
|
Items = genresResult.Items.Select(i => i.Item1).ToArray()
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return ToResult(result);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<ServerItem> GetMusicGenres(BaseItem parent, User user, InternalItemsQuery query)
|
|
|
|
private QueryResult<ServerItem> GetMusicGenres(BaseItem parent, User user, InternalItemsQuery query)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var genresResult = _libraryManager.GetMusicGenres(new InternalItemsQuery(user)
|
|
|
|
var genresResult = _libraryManager.GetMusicGenres(new InternalItemsQuery(user)
|
|
|
@ -810,6 +1103,55 @@ namespace Emby.Dlna.ContentDirectory
|
|
|
|
return ToResult(items);
|
|
|
|
return ToResult(items);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<ServerItem> GetNextUp(BaseItem parent, User user, InternalItemsQuery query)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
query.SortBy = new string[] { };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var result = _tvSeriesManager.GetNextUp(new NextUpQuery
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
Limit = query.Limit,
|
|
|
|
|
|
|
|
StartIndex = query.StartIndex,
|
|
|
|
|
|
|
|
UserId = query.User.Id.ToString("N")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}, new List<Folder> { (Folder)parent }, query.DtoOptions);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return ToResult(result);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<ServerItem> GetTvLatest(BaseItem parent, User user, InternalItemsQuery query)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
query.SortBy = new string[] { };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var items = _userViewManager.GetLatestItems(new LatestItemsQuery
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
UserId = user.Id.ToString("N"),
|
|
|
|
|
|
|
|
Limit = 50,
|
|
|
|
|
|
|
|
IncludeItemTypes = new[] { typeof(Episode).Name },
|
|
|
|
|
|
|
|
ParentId = parent == null ? null : parent.Id.ToString("N"),
|
|
|
|
|
|
|
|
GroupItems = true
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}, query.DtoOptions).Select(i => i.Item1 ?? i.Item2.FirstOrDefault()).Where(i => i != null).ToList();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return ToResult(items);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<ServerItem> GetMovieLatest(BaseItem parent, User user, InternalItemsQuery query)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
query.SortBy = new string[] { };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var items = _userViewManager.GetLatestItems(new LatestItemsQuery
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
UserId = user.Id.ToString("N"),
|
|
|
|
|
|
|
|
Limit = 50,
|
|
|
|
|
|
|
|
IncludeItemTypes = new[] { typeof(Movie).Name },
|
|
|
|
|
|
|
|
ParentId = parent == null ? null : parent.Id.ToString("N"),
|
|
|
|
|
|
|
|
GroupItems = true
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}, query.DtoOptions).Select(i => i.Item1 ?? i.Item2.FirstOrDefault()).Where(i => i != null).ToList();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return ToResult(items);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private QueryResult<ServerItem> GetMusicArtistItems(BaseItem item, Guid? parentId, User user, SortCriteria sort, int? startIndex, int? limit)
|
|
|
|
private QueryResult<ServerItem> GetMusicArtistItems(BaseItem item, Guid? parentId, User user, SortCriteria sort, int? startIndex, int? limit)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var query = new InternalItemsQuery(user)
|
|
|
|
var query = new InternalItemsQuery(user)
|
|
|
@ -942,65 +1284,16 @@ namespace Emby.Dlna.ContentDirectory
|
|
|
|
id = parts[23];
|
|
|
|
id = parts[23];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (id.StartsWith("folder_", StringComparison.OrdinalIgnoreCase))
|
|
|
|
var enumNames = Enum.GetNames(typeof(StubType));
|
|
|
|
{
|
|
|
|
foreach (var name in enumNames)
|
|
|
|
stubType = StubType.Folder;
|
|
|
|
|
|
|
|
id = id.Split(new[] { '_' }, 2)[1];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (id.StartsWith("people_", StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
stubType = StubType.People;
|
|
|
|
|
|
|
|
id = id.Split(new[] { '_' }, 2)[1];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (id.StartsWith("latest_", StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
stubType = StubType.Latest;
|
|
|
|
|
|
|
|
id = id.Split(new[] { '_' }, 2)[1];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (id.StartsWith("playlists_", StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
stubType = StubType.Playlists;
|
|
|
|
|
|
|
|
id = id.Split(new[] { '_' }, 2)[1];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (id.StartsWith("Albums_", StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
stubType = StubType.Albums;
|
|
|
|
|
|
|
|
id = id.Split(new[] { '_' }, 2)[1];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (id.StartsWith("AlbumArtists_", StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
stubType = StubType.AlbumArtists;
|
|
|
|
|
|
|
|
id = id.Split(new[] { '_' }, 2)[1];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (id.StartsWith("Artists_", StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
stubType = StubType.Artists;
|
|
|
|
if (id.StartsWith(name + "_", StringComparison.OrdinalIgnoreCase))
|
|
|
|
id = id.Split(new[] { '_' }, 2)[1];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (id.StartsWith("Genres_", StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
stubType = StubType.Genres;
|
|
|
|
|
|
|
|
id = id.Split(new[] { '_' }, 2)[1];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (id.StartsWith("Songs_", StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
stubType = StubType.Songs;
|
|
|
|
stubType = (StubType)Enum.Parse(typeof(StubType), name, true);
|
|
|
|
id = id.Split(new[] { '_' }, 2)[1];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (id.StartsWith("FavoriteAlbums_", StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
stubType = StubType.FavoriteAlbums;
|
|
|
|
|
|
|
|
id = id.Split(new[] { '_' }, 2)[1];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if (id.StartsWith("FavoriteArtists_", StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
stubType = StubType.FavoriteArtists;
|
|
|
|
|
|
|
|
id = id.Split(new[] { '_' }, 2)[1];
|
|
|
|
id = id.Split(new[] { '_' }, 2)[1];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (id.StartsWith("FavoriteSongs_", StringComparison.OrdinalIgnoreCase))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
stubType = StubType.FavoriteSongs;
|
|
|
|
|
|
|
|
id = id.Split(new[] { '_' }, 2)[1];
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (Guid.TryParse(id, out itemId))
|
|
|
|
if (Guid.TryParse(id, out itemId))
|
|
|
@ -1048,6 +1341,14 @@ namespace Emby.Dlna.ContentDirectory
|
|
|
|
Genres = 8,
|
|
|
|
Genres = 8,
|
|
|
|
FavoriteSongs = 9,
|
|
|
|
FavoriteSongs = 9,
|
|
|
|
FavoriteArtists = 10,
|
|
|
|
FavoriteArtists = 10,
|
|
|
|
FavoriteAlbums = 11
|
|
|
|
FavoriteAlbums = 11,
|
|
|
|
|
|
|
|
ContinueWatching = 12,
|
|
|
|
|
|
|
|
Movies = 13,
|
|
|
|
|
|
|
|
Collections = 14,
|
|
|
|
|
|
|
|
Favorites = 15,
|
|
|
|
|
|
|
|
NextUp = 16,
|
|
|
|
|
|
|
|
Series = 17,
|
|
|
|
|
|
|
|
FavoriteSeries = 18,
|
|
|
|
|
|
|
|
FavoriteEpisodes = 19
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|