Source code for woob.capabilities.bands
# Copyright(C) 2018 Quentin Defenouillere
#
# This file is part of woob.
#
# woob is free software: you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# woob is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public License
# along with woob. If not, see <http://www.gnu.org/licenses/>.
from .base import BaseObject, Capability, StringField, UserError
__all__ = [
"BandInfo",
"BandSearch",
"Albums",
"BandNotFound",
"Suggestion",
"Favorite",
"CapBands",
]
[docs]class BandSearch(BaseObject):
"""
Bands search.
"""
name = StringField("Name of band")
short_description = StringField("Short description of the band")
def __init__(self, id="", name=None, short_description=None, url=None):
super().__init__(id, url)
self.name = name
self.short_description = short_description
[docs]class BandNotFound(UserError):
"""
Raised when no band is found.
"""
pass
[docs]class BandInfo(BaseObject):
"""
Information about one specific band.
"""
name = StringField("Name of band")
genre = StringField("Music genre of the band")
year = StringField("Year of creation")
country = StringField("Country of origin")
description = StringField("Description of the band")
def __init__(self, name=None, year=None, country=None, genre=None, description=None, url=None):
super().__init__(id, url)
self.name = name
self.genre = genre
self.year = year
self.description = description
self.country = country
[docs]class Albums(BaseObject):
"""
Information about one specific band.
"""
name = StringField("Album name")
album_type = StringField("Type of album")
year = StringField("Year of release")
reviews = StringField("Album reviews")
def __init__(self, name=None, album_type=None, year=None, reviews=None, url=None):
super().__init__(id, url)
self.name = name
self.album_type = album_type
self.year = year
self.reviews = reviews
[docs]class Favorite(BaseObject):
"""
Fetch your favorite bands.
"""
name = StringField("Name of favorite band")
band_url = StringField("URL of the favorite band")
short_description = StringField("Short description of the favorite band")
def __init__(self, id="", name=None, band_url=None, short_description=None):
super().__init__(id, name)
self.name = name
self.band_url = band_url
self.short_description = short_description
[docs]class Suggestion(BaseObject):
"""
Band suggestions based on your favorite bands.
"""
name = StringField("Name of suggested band")
description = StringField("Band description")
url = StringField("URL of suggested band")
def __init__(self, id="", name=None, description=None, url=None):
super().__init__(id, url)
self.name = name
self.url = url
self.description = description
[docs]class CapBands(Capability):
"""
Capability to get band information on music websites.
"""
[docs] def iter_band_search(self):
"""
Look for a band.
:param pattern: pattern to search
:type pattern: str
:rtype: iter[:class:`BandSearch`]
"""
raise NotImplementedError()
[docs] def get_info(self):
"""
Get band info.
:param band_id: ID of the band
:rtype: :class:`BandInfo`
"""
raise NotImplementedError()
[docs] def get_albums(self):
"""
Get a band's discography.
:rtype: iter[:class:`Albums`]
"""
raise NotImplementedError()
[docs] def get_favorites(self):
"""
Get my favorite bands.
:rtype: iter[:class:`Favorite`]
"""
raise NotImplementedError()
[docs] def suggestions(self):
"""
Get band suggestions according to your favorite bands.
:rtype: iter[:class:`Suggestion`]
"""
raise NotImplementedError()