aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLuke Pulverenti <luke.pulverenti@gmail.com>2013-07-27 14:24:48 -0400
committerLuke Pulverenti <luke.pulverenti@gmail.com>2013-07-27 14:24:48 -0400
commit898d55d8663d4426ee03a3f72b2f566585e489c8 (patch)
tree5b11a6706951ada619ecd773c426d8e90d6cf795
parenta4142e87647cadda1b3a157935e500ade683cc38 (diff)
factor collection type in resolving process
-rw-r--r--MediaBrowser.Model/ApiClient/IApiClient.cs16
-rw-r--r--MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicAlbumResolver.cs18
-rw-r--r--MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicArtistResolver.cs18
-rw-r--r--MediaBrowser.Server.Implementations/Library/Resolvers/TV/SeriesResolver.cs16
4 files changed, 68 insertions, 0 deletions
diff --git a/MediaBrowser.Model/ApiClient/IApiClient.cs b/MediaBrowser.Model/ApiClient/IApiClient.cs
index b15d1c1d5..b99773e4d 100644
--- a/MediaBrowser.Model/ApiClient/IApiClient.cs
+++ b/MediaBrowser.Model/ApiClient/IApiClient.cs
@@ -241,6 +241,22 @@ namespace MediaBrowser.Model.ApiClient
Task<BaseItemDto> GetGenreAsync(string name, string userId);
/// <summary>
+ /// Gets the music genre async.
+ /// </summary>
+ /// <param name="name">The name.</param>
+ /// <param name="userId">The user id.</param>
+ /// <returns>Task{BaseItemDto}.</returns>
+ Task<BaseItemDto> GetMusicGenreAsync(string name, string userId);
+
+ /// <summary>
+ /// Gets the game genre async.
+ /// </summary>
+ /// <param name="name">The name.</param>
+ /// <param name="userId">The user id.</param>
+ /// <returns>Task{BaseItemDto}.</returns>
+ Task<BaseItemDto> GetGameGenreAsync(string name, string userId);
+
+ /// <summary>
/// Gets the artist async.
/// </summary>
/// <param name="name">The name.</param>
diff --git a/MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicAlbumResolver.cs b/MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicAlbumResolver.cs
index 209ae0e45..0ac0f0533 100644
--- a/MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicAlbumResolver.cs
+++ b/MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicAlbumResolver.cs
@@ -1,6 +1,8 @@
using MediaBrowser.Controller.Entities.Audio;
using MediaBrowser.Controller.Library;
using MediaBrowser.Controller.Resolvers;
+using MediaBrowser.Model.Entities;
+using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
@@ -12,6 +14,13 @@ namespace MediaBrowser.Server.Implementations.Library.Resolvers.Audio
/// </summary>
public class MusicAlbumResolver : ItemResolver<MusicAlbum>
{
+ private readonly ILibraryManager _libraryManager;
+
+ public MusicAlbumResolver(ILibraryManager libraryManager)
+ {
+ _libraryManager = libraryManager;
+ }
+
/// <summary>
/// Gets the priority.
/// </summary>
@@ -35,6 +44,15 @@ namespace MediaBrowser.Server.Implementations.Library.Resolvers.Audio
if (args.Parent.IsRoot) return null;
if (args.Parent is MusicAlbum) return null;
+ var collectionType = args.Parent == null ? null : _libraryManager.FindCollectionType(args.Parent);
+
+ // If there's a collection type and it's not music, it can't be a series
+ if (!string.IsNullOrEmpty(collectionType) &&
+ !string.Equals(collectionType, CollectionType.Music, StringComparison.OrdinalIgnoreCase))
+ {
+ return null;
+ }
+
return IsMusicAlbum(args) ? new MusicAlbum
{
DisplayMediaType = "Album"
diff --git a/MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicArtistResolver.cs b/MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicArtistResolver.cs
index fa34a6a2e..e2c71f613 100644
--- a/MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicArtistResolver.cs
+++ b/MediaBrowser.Server.Implementations/Library/Resolvers/Audio/MusicArtistResolver.cs
@@ -1,6 +1,8 @@
using MediaBrowser.Controller.Entities.Audio;
using MediaBrowser.Controller.Library;
using MediaBrowser.Controller.Resolvers;
+using MediaBrowser.Model.Entities;
+using System;
using System.IO;
using System.Linq;
@@ -11,6 +13,13 @@ namespace MediaBrowser.Server.Implementations.Library.Resolvers.Audio
/// </summary>
public class MusicArtistResolver : ItemResolver<MusicArtist>
{
+ private readonly ILibraryManager _libraryManager;
+
+ public MusicArtistResolver(ILibraryManager libraryManager)
+ {
+ _libraryManager = libraryManager;
+ }
+
/// <summary>
/// Gets the priority.
/// </summary>
@@ -39,6 +48,15 @@ namespace MediaBrowser.Server.Implementations.Library.Resolvers.Audio
return null;
}
+ var collectionType = args.Parent == null ? null : _libraryManager.FindCollectionType(args.Parent);
+
+ // If there's a collection type and it's not music, it can't be a series
+ if (!string.IsNullOrEmpty(collectionType) &&
+ !string.Equals(collectionType, CollectionType.Music, StringComparison.OrdinalIgnoreCase))
+ {
+ return null;
+ }
+
// If we contain an album assume we are an artist folder
return args.FileSystemChildren.Where(i => (i.Attributes & FileAttributes.Directory) == FileAttributes.Directory).Any(i => MusicAlbumResolver.IsMusicAlbum(i.FullName)) ? new MusicArtist() : null;
}
diff --git a/MediaBrowser.Server.Implementations/Library/Resolvers/TV/SeriesResolver.cs b/MediaBrowser.Server.Implementations/Library/Resolvers/TV/SeriesResolver.cs
index 10e73b288..9c8f4dceb 100644
--- a/MediaBrowser.Server.Implementations/Library/Resolvers/TV/SeriesResolver.cs
+++ b/MediaBrowser.Server.Implementations/Library/Resolvers/TV/SeriesResolver.cs
@@ -13,6 +13,13 @@ namespace MediaBrowser.Server.Implementations.Library.Resolvers.TV
/// </summary>
public class SeriesResolver : FolderResolver<Series>
{
+ private readonly ILibraryManager _libraryManager;
+
+ public SeriesResolver(ILibraryManager libraryManager)
+ {
+ _libraryManager = libraryManager;
+ }
+
/// <summary>
/// Gets the priority.
/// </summary>
@@ -46,6 +53,15 @@ namespace MediaBrowser.Server.Implementations.Library.Resolvers.TV
return null;
}
+ var collectionType = args.Parent == null ? null : _libraryManager.FindCollectionType(args.Parent);
+
+ // If there's a collection type and it's not tv, it can't be a series
+ if (!string.IsNullOrEmpty(collectionType) &&
+ !string.Equals(collectionType, CollectionType.TvShows, StringComparison.OrdinalIgnoreCase))
+ {
+ return null;
+ }
+
// It's a Series if any of the following conditions are met:
// series.xml exists
// [tvdbid= is present in the path