[Grooveshark] add user playlist management
This commit is contained in:
parent
72a4de7e30
commit
6fa693f5aa
3 changed files with 99 additions and 20 deletions
|
|
@ -18,10 +18,11 @@
|
|||
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
|
||||
from weboob.tools.backend import BaseBackend
|
||||
from weboob.tools.backend import BaseBackend, BackendConfig
|
||||
from weboob.capabilities.video import ICapVideo, BaseVideo
|
||||
from weboob.capabilities.collection import ICapCollection, Collection, CollectionNotFound
|
||||
from .browser import GroovesharkBrowser
|
||||
from weboob.tools.value import ValueBackendPassword, Value
|
||||
|
||||
__all__ = ['GroovesharkBackend']
|
||||
|
||||
|
|
@ -35,6 +36,15 @@ class GroovesharkBackend(BaseBackend, ICapVideo, ICapCollection):
|
|||
LICENSE = 'AGPLv3+'
|
||||
|
||||
BROWSER = GroovesharkBrowser
|
||||
CONFIG = BackendConfig(Value('username', label='Login', default=''),
|
||||
ValueBackendPassword('password', label='Password', default=''))
|
||||
|
||||
def create_default_browser(self):
|
||||
password = None
|
||||
username = self.config['username'].get()
|
||||
if len(username) > 0:
|
||||
password = self.config['password'].get()
|
||||
return self.create_browser(username, password)
|
||||
|
||||
def fill_video(self, video, fields):
|
||||
if 'url' in fields:
|
||||
|
|
@ -58,11 +68,21 @@ class GroovesharkBackend(BaseBackend, ICapVideo, ICapCollection):
|
|||
collection = self.get_collection(objs, split_path)
|
||||
if collection.path_level == 0:
|
||||
yield Collection([u'albums'], u'Search for Albums')
|
||||
if self.browser.is_logged:
|
||||
yield Collection([u'playlists'], u'Grooveshark Playlists')
|
||||
if collection.path_level == 1:
|
||||
print u'Enter cd [%s\'s name] then ls to launch search' % collection.split_path[0]
|
||||
if collection.path_level == 2 and collection.split_path[0] == u'albums':
|
||||
for item in self.browser.search_albums(collection.split_path):
|
||||
yield item
|
||||
if collection.split_path[0] == u'playlists':
|
||||
for item in self.browser.get_all_user_playlists(collection.split_path):
|
||||
yield item
|
||||
elif collection.split_path[0] == u'albums':
|
||||
print u'Enter cd [%s\'s name] then ls to launch search' % collection.split_path[0]
|
||||
if collection.path_level == 2:
|
||||
if collection.split_path[0] == u'albums':
|
||||
for item in self.browser.search_albums(collection.split_path):
|
||||
yield item
|
||||
if collection.split_path[0] == u'playlists':
|
||||
for video in self.browser.get_all_songs_from_playlist(collection.split_path[1]):
|
||||
yield video
|
||||
if collection.path_level == 3 and collection.split_path[0] == u'albums':
|
||||
for video in self.browser.get_all_songs_from_album(collection.split_path[2]):
|
||||
yield video
|
||||
|
|
@ -71,11 +91,17 @@ class GroovesharkBackend(BaseBackend, ICapVideo, ICapCollection):
|
|||
if collection.path_level == 0:
|
||||
return
|
||||
|
||||
if BaseVideo in objs and collection.split_path == [u'albums']:
|
||||
if BaseVideo in objs and (collection.split_path == [u'albums'] or collection.split_path == [u'playlists']):
|
||||
return
|
||||
|
||||
if BaseVideo in objs and collection.path_level == 2 and \
|
||||
(collection.split_path[0] == u'albums'):
|
||||
(collection.split_path[0] == u'albums' or collection.split_path[0] == u'playlists'):
|
||||
if collection.split_path[0] == u'playlists':
|
||||
try:
|
||||
int(collection.split_path[1])
|
||||
except ValueError:
|
||||
raise CollectionNotFound(collection.split_path)
|
||||
|
||||
return
|
||||
|
||||
if BaseVideo in objs and collection.path_level == 3 and \
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue