Listing genres
This commit is contained in:
parent
e9fff5d8d5
commit
4c7a5192cb
3 changed files with 56 additions and 3 deletions
|
@ -16,6 +16,7 @@ class SubidyLibraryProvider(backend.LibraryProvider):
|
||||||
dict(id="rootdirs", name="Directories"),
|
dict(id="rootdirs", name="Directories"),
|
||||||
dict(id="random", name="Random"),
|
dict(id="random", name="Random"),
|
||||||
dict(id="randomalbum", name="Random Albums"),
|
dict(id="randomalbum", name="Random Albums"),
|
||||||
|
dict(id="genre", name="Genre"),
|
||||||
]
|
]
|
||||||
# Create a dict with the keys being the `id`s in `vdir_templates`
|
# Create a dict with the keys being the `id`s in `vdir_templates`
|
||||||
# and the values being objects containing the vdir `id`,
|
# and the values being objects containing the vdir `id`,
|
||||||
|
@ -60,6 +61,12 @@ class SubidyLibraryProvider(backend.LibraryProvider):
|
||||||
def browse_random_albums(self):
|
def browse_random_albums(self):
|
||||||
return self.subsonic_api.get_random_albums_as_refs()
|
return self.subsonic_api.get_random_albums_as_refs()
|
||||||
|
|
||||||
|
def browse_albums_by_genre(self, genre):
|
||||||
|
return self.subsonic_api.get_albums_by_genre_as_refs(genre)
|
||||||
|
|
||||||
|
def browse_genre(self):
|
||||||
|
return self.subsonic_api.get_genres_as_refs(genre)
|
||||||
|
|
||||||
def browse_diritems(self, directory_id):
|
def browse_diritems(self, directory_id):
|
||||||
return self.subsonic_api.get_diritems_as_refs(directory_id)
|
return self.subsonic_api.get_diritems_as_refs(directory_id)
|
||||||
|
|
||||||
|
@ -90,7 +97,8 @@ class SubidyLibraryProvider(backend.LibraryProvider):
|
||||||
|
|
||||||
def browse(self, browse_uri):
|
def browse(self, browse_uri):
|
||||||
if browse_uri == uri.get_vdir_uri("root"):
|
if browse_uri == uri.get_vdir_uri("root"):
|
||||||
root_vdir_names = ["rootdirs", "artists", "albums", "random", "randomalbum"]
|
root_vdir_names = ["rootdirs", "artists",
|
||||||
|
"albums", "random", "randomalbum", "genre"]
|
||||||
root_vdirs = [
|
root_vdirs = [
|
||||||
self._vdirs[vdir_name] for vdir_name in root_vdir_names
|
self._vdirs[vdir_name] for vdir_name in root_vdir_names
|
||||||
]
|
]
|
||||||
|
@ -108,11 +116,15 @@ class SubidyLibraryProvider(backend.LibraryProvider):
|
||||||
return self.browse_random_songs()
|
return self.browse_random_songs()
|
||||||
elif browse_uri == uri.get_vdir_uri("randomalbum"):
|
elif browse_uri == uri.get_vdir_uri("randomalbum"):
|
||||||
return self.browse_random_albums()
|
return self.browse_random_albums()
|
||||||
|
elif browse_uri == uri.get_vdir_uri("genre"):
|
||||||
|
return self.browse_genre()
|
||||||
|
|
||||||
else:
|
else:
|
||||||
uri_type = uri.get_type(browse_uri)
|
uri_type = uri.get_type(browse_uri)
|
||||||
if uri_type == uri.DIRECTORY:
|
if uri_type == uri.DIRECTORY:
|
||||||
return self.browse_diritems(uri.get_directory_id(browse_uri))
|
return self.browse_diritems(uri.get_directory_id(browse_uri))
|
||||||
|
elif uri_type == uri.GENRE:
|
||||||
|
return self.browse_albums_by_genre(uri.get_genre_id(browse_uri))
|
||||||
elif uri_type == uri.ARTIST:
|
elif uri_type == uri.ARTIST:
|
||||||
return self.browse_albums(uri.get_artist_id(browse_uri))
|
return self.browse_albums(uri.get_artist_id(browse_uri))
|
||||||
elif uri_type == uri.ALBUM:
|
elif uri_type == uri.ALBUM:
|
||||||
|
|
|
@ -450,6 +450,28 @@ class SubsonicApi:
|
||||||
return albums
|
return albums
|
||||||
return []
|
return []
|
||||||
|
|
||||||
|
def get_raw_genres(self):
|
||||||
|
try:
|
||||||
|
response = self.connection.getGenres()
|
||||||
|
except Exception:
|
||||||
|
logger.warning(
|
||||||
|
"Connecting to subsonic failed when loading genres."
|
||||||
|
)
|
||||||
|
return []
|
||||||
|
|
||||||
|
if response.get("status") != RESPONSE_OK:
|
||||||
|
logger.warning(
|
||||||
|
"Got non-okay status code from subsonic: %s"
|
||||||
|
% response.get("status")
|
||||||
|
)
|
||||||
|
return []
|
||||||
|
|
||||||
|
genres = response.get("genres").get("genre")
|
||||||
|
|
||||||
|
if genres is not None:
|
||||||
|
return genres
|
||||||
|
return []
|
||||||
|
|
||||||
def get_more_albums(self, ltype, size=MAX_LIST_RESULTS, offset=0):
|
def get_more_albums(self, ltype, size=MAX_LIST_RESULTS, offset=0):
|
||||||
try:
|
try:
|
||||||
response = self.connection.getAlbumList2(
|
response = self.connection.getAlbumList2(
|
||||||
|
@ -597,6 +619,16 @@ class SubsonicApi:
|
||||||
else:
|
else:
|
||||||
yield self.raw_song_to_track(item)
|
yield self.raw_song_to_track(item)
|
||||||
|
|
||||||
|
def get_albums_by_genre_as_refs(self, genre):
|
||||||
|
return []
|
||||||
|
|
||||||
|
def get_genres_as_refs(self):
|
||||||
|
genres = self.get_raw_genres()
|
||||||
|
return [Ref.directory(
|
||||||
|
name=genre.value,
|
||||||
|
uri=uri.get_genre_uri(genre.value)
|
||||||
|
) for genre in genres]
|
||||||
|
|
||||||
def raw_song_to_ref(self, song):
|
def raw_song_to_ref(self, song):
|
||||||
if song is None:
|
if song is None:
|
||||||
return None
|
return None
|
||||||
|
@ -646,8 +678,8 @@ class SubsonicApi:
|
||||||
return None
|
return None
|
||||||
return Ref.album(
|
return Ref.album(
|
||||||
name=album.get("artist") + " - " + album.get("title")
|
name=album.get("artist") + " - " + album.get("title")
|
||||||
or album.get("artist") + " - " + album.get("name")
|
or album.get("artist") + " - " + album.get("name")
|
||||||
or UNKNOWN_ALBUM,
|
or UNKNOWN_ALBUM,
|
||||||
uri=uri.get_album_uri(album.get("id")),
|
uri=uri.get_album_uri(album.get("id")),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -712,3 +744,4 @@ class SubsonicApi:
|
||||||
uri=uri.get_playlist_uri(playlist.get("id")),
|
uri=uri.get_playlist_uri(playlist.get("id")),
|
||||||
name=playlist.get("name"),
|
name=playlist.get("name"),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,7 @@ PLAYLIST = "playlist"
|
||||||
ALBUM = "album"
|
ALBUM = "album"
|
||||||
DIRECTORY = "directory"
|
DIRECTORY = "directory"
|
||||||
VDIR = "vdir"
|
VDIR = "vdir"
|
||||||
|
GENRE = "genre"
|
||||||
PREFIX = "subidy"
|
PREFIX = "subidy"
|
||||||
SEARCH = "search"
|
SEARCH = "search"
|
||||||
RANDOM = "random"
|
RANDOM = "random"
|
||||||
|
@ -70,6 +71,11 @@ def get_vdir_id(uri):
|
||||||
return None
|
return None
|
||||||
return result.group(3)
|
return result.group(3)
|
||||||
|
|
||||||
|
def get_genre_id(uri):
|
||||||
|
result = regex.match(uri)
|
||||||
|
if not is_id_result_valid(result, GENRE):
|
||||||
|
return None
|
||||||
|
return result.group(3)
|
||||||
|
|
||||||
def get_type(uri):
|
def get_type(uri):
|
||||||
result = regex.match(uri)
|
result = regex.match(uri)
|
||||||
|
@ -97,6 +103,8 @@ def get_song_uri(id):
|
||||||
def get_directory_uri(id):
|
def get_directory_uri(id):
|
||||||
return get_type_uri(DIRECTORY, id)
|
return get_type_uri(DIRECTORY, id)
|
||||||
|
|
||||||
|
def get_genre_uri(id):
|
||||||
|
return get_type_uri(GENRE, id)
|
||||||
|
|
||||||
def get_vdir_uri(id):
|
def get_vdir_uri(id):
|
||||||
return get_type_uri(VDIR, id)
|
return get_type_uri(VDIR, id)
|
||||||
|
|
Loading…
Add table
Reference in a new issue