correct conflict
This commit is contained in:
commit
876bec6711
3 changed files with 44 additions and 1 deletions
|
@ -14,6 +14,7 @@ class SubidyLibraryProvider(backend.LibraryProvider):
|
||||||
dict(id="artists", name="Artists"),
|
dict(id="artists", name="Artists"),
|
||||||
dict(id="albums", name="Albums"),
|
dict(id="albums", name="Albums"),
|
||||||
dict(id="rootdirs", name="Directories"),
|
dict(id="rootdirs", name="Directories"),
|
||||||
|
dict(id="random", name="Random"),
|
||||||
]
|
]
|
||||||
# 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`,
|
||||||
|
@ -52,6 +53,9 @@ class SubidyLibraryProvider(backend.LibraryProvider):
|
||||||
def browse_rootdirs(self):
|
def browse_rootdirs(self):
|
||||||
return self.subsonic_api.get_rootdirs_as_refs()
|
return self.subsonic_api.get_rootdirs_as_refs()
|
||||||
|
|
||||||
|
def browse_random_songs(self):
|
||||||
|
return self.subsonic_api.get_random_songs_as_refs()
|
||||||
|
|
||||||
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)
|
||||||
|
|
||||||
|
@ -82,7 +86,7 @@ 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"]
|
root_vdir_names = ["rootdirs", "artists", "albums", "random"]
|
||||||
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
|
||||||
]
|
]
|
||||||
|
@ -96,6 +100,9 @@ class SubidyLibraryProvider(backend.LibraryProvider):
|
||||||
return self.browse_artists()
|
return self.browse_artists()
|
||||||
elif browse_uri == uri.get_vdir_uri("albums"):
|
elif browse_uri == uri.get_vdir_uri("albums"):
|
||||||
return self.browse_albums()
|
return self.browse_albums()
|
||||||
|
elif browse_uri == uri.get_vdir_uri("random"):
|
||||||
|
return self.browse_random_songs()
|
||||||
|
|
||||||
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:
|
||||||
|
@ -193,6 +200,11 @@ class SubidyLibraryProvider(backend.LibraryProvider):
|
||||||
)
|
)
|
||||||
if "artist" in query:
|
if "artist" in query:
|
||||||
return self.search_by_artist(query.get("artist")[0], exact)
|
return self.search_by_artist(query.get("artist")[0], exact)
|
||||||
|
if "comment" in query:
|
||||||
|
if query.get("comment")[0] == "random":
|
||||||
|
return SearchResult(
|
||||||
|
tracks=self.subsonic_api.get_random_songs_as_tracks()
|
||||||
|
)
|
||||||
if "any" in query:
|
if "any" in query:
|
||||||
return self.subsonic_api.find_as_search_result(query.get("any")[0])
|
return self.subsonic_api.find_as_search_result(query.get("any")[0])
|
||||||
return SearchResult(artists=self.subsonic_api.get_artists_as_artists())
|
return SearchResult(artists=self.subsonic_api.get_artists_as_artists())
|
||||||
|
|
|
@ -410,6 +410,25 @@ class SubsonicApi:
|
||||||
return songs
|
return songs
|
||||||
return []
|
return []
|
||||||
|
|
||||||
|
def get_raw_random_song(self, size=MAX_LIST_RESULTS):
|
||||||
|
try:
|
||||||
|
response = self.connection.getRandomSongs(size)
|
||||||
|
except Exception:
|
||||||
|
logger.warning(
|
||||||
|
"Connecting to subsonic failed when loading list of songs in album."
|
||||||
|
)
|
||||||
|
return []
|
||||||
|
if response.get("status") != RESPONSE_OK:
|
||||||
|
logger.warning(
|
||||||
|
"Got non-okay status code from subsonic: %s"
|
||||||
|
% response.get("status")
|
||||||
|
)
|
||||||
|
return []
|
||||||
|
songs = response.get("randomSongs").get("song")
|
||||||
|
if songs is not None:
|
||||||
|
return songs
|
||||||
|
return []
|
||||||
|
|
||||||
def get_raw_album_list(self, ltype, size=MAX_LIST_RESULTS):
|
def get_raw_album_list(self, ltype, size=MAX_LIST_RESULTS):
|
||||||
try:
|
try:
|
||||||
response = self.connection.getAlbumList2(ltype=ltype, size=size)
|
response = self.connection.getAlbumList2(ltype=ltype, size=size)
|
||||||
|
@ -475,6 +494,17 @@ class SubsonicApi:
|
||||||
for diritem in self.get_raw_dir(directory_id)
|
for diritem in self.get_raw_dir(directory_id)
|
||||||
]
|
]
|
||||||
|
|
||||||
|
def get_random_songs_as_refs(self):
|
||||||
|
return [
|
||||||
|
self.raw_song_to_ref(song) for song in self.get_raw_random_song(75)
|
||||||
|
]
|
||||||
|
|
||||||
|
def get_random_songs_as_tracks(self):
|
||||||
|
return [
|
||||||
|
self.raw_song_to_track(song)
|
||||||
|
for song in self.get_raw_random_song(MAX_LIST_RESULTS)
|
||||||
|
]
|
||||||
|
|
||||||
def get_artists_as_artists(self):
|
def get_artists_as_artists(self):
|
||||||
return [
|
return [
|
||||||
self.raw_artist_to_artist(artist)
|
self.raw_artist_to_artist(artist)
|
||||||
|
|
|
@ -8,6 +8,7 @@ DIRECTORY = "directory"
|
||||||
VDIR = "vdir"
|
VDIR = "vdir"
|
||||||
PREFIX = "subidy"
|
PREFIX = "subidy"
|
||||||
SEARCH = "search"
|
SEARCH = "search"
|
||||||
|
RANDOM = "random"
|
||||||
|
|
||||||
regex = re.compile(r"(\w+?):(\w+?)(?::|$)(.+?)?$")
|
regex = re.compile(r"(\w+?):(\w+?)(?::|$)(.+?)?$")
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue