Example #1
0
class DiffArtists(db.Model, BaseDiff):
    __tablename__ = 'diff_artists'

    id = db.Column(db.Integer, primary_key=True)

    artist1 = db.Column(db.String(255), nullable=False)
    artist2 = db.Column(db.String(255), nullable=False)
Example #2
0
class DiffTracks(db.Model, BaseDiff):
    __tablename__ = 'diff_tracks'

    id = db.Column(db.Integer, primary_key=True)

    artist = db.Column(db.String(255), nullable=False)
    track1 = db.Column(db.String(255), nullable=False)
    track2 = db.Column(db.String(255), nullable=False)
Example #3
0
class TrackCorrection(BaseCorrection, db.Model):
    __tablename__ = 'correction_tracks'

    artist_id = db.Column(db.Integer,
                          db.ForeignKey('artists.id'),
                          nullable=False)
    artist = relationship('Artist')
Example #4
0
class NowPlaying(db.Model, BaseScrobble):
    __tablename__ = 'np'

    token_id = db.Column(db.Integer, db.ForeignKey('tokens.id'), nullable=True)
    token = relationship('Token')

    def __repr__(self):
        return "<NP #{id}: {artist} - {track}>".format(id=self.id,
                                                       artist=self.artist,
                                                       track=self.track)
Example #5
0
class Token(db.Model):
    __tablename__ = 'tokens'

    id = db.Column(db.Integer, primary_key=True)
    created_at = db.Column(db.DateTime(timezone=True),
                           nullable=False,
                           default=datetime.now)

    user_id = db.Column(db.Integer, db.ForeignKey('users.id'), nullable=False)

    name = db.Column(db.String(64))
    _key = db.Column('key', db.String(32))

    is_active = db.Column(db.Boolean, default=True, nullable=False)

    @hybrid_property
    def key(self):
        return self._key

    @key.setter
    def _set_key(self, data):
        self._key = md5(data)

    def __repr__(self):
        return "<Token {user_id}/{name}>".format(user_id=self.user_id,
                                                 name=self.name)
Example #6
0
class Artist(db.Model):
    __tablename__ = 'artists'

    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(255), nullable=False)
    # initial_name = db.Column(db.String(255))
    bio = db.Column(db.Text)
    image_url = db.Column(db.String(255))
    playcount = db.Column(db.Integer, default=0)
    local_playcount = db.Column(db.Integer, default=0)
    mbid = db.Column(db.String(64))
    tags = db.Column(JSONB)
    genre = db.Column(db.String(64))

    def __str__(self):
        return self.name

    def __repr__(self):
        return "<Artist #{id}: {artist}>".format(id=self.id, artist=self.name)
Example #7
0
class Album(db.Model):
    __tablename__ = 'albums'

    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(255), nullable=False)
    artist_id = db.Column(db.Integer,
                          db.ForeignKey('artists.id'),
                          nullable=True)
    artist = relationship('Artist')
    date = db.Column(db.Date)
    image_url = db.Column(db.String(255))
    playcount = db.Column(db.Integer, default=0)
    local_playcount = db.Column(db.Integer, default=0)
    tags = db.Column(JSONB)
    genre = db.Column(db.String(64))

    def __str__(self):
        return self.name

    def __repr__(self):
        return "<Artist #{id}: {artist}>".format(id=self.id, artist=self.name)
Example #8
0
class BaseScrobble(object):
    id = db.Column(db.Integer, primary_key=True)

    @declared_attr
    def user_id(cls):
        return db.Column(db.Integer, db.ForeignKey('users.id'), nullable=False)

    played_at = db.Column(db.DateTime(timezone=True), nullable=False)

    # Track metadata
    artist = db.Column(db.String(255), nullable=False)
    track = db.Column(db.String(255), nullable=False)
    album = db.Column(db.String(255))
    tracknumber = db.Column(db.String(255))
    length = db.Column(db.Interval, nullable=False)
    musicbrainz = db.Column(db.String(255))

    def __str__(self):
        return "{artist} - {track}".format(artist=self.artist,
                                           track=self.track)
Example #9
0
class Session(db.Model):
    __tablename__ = 'sessions'

    id = db.Column(db.Integer, primary_key=True)
    session_id = db.Column(db.String(32))

    user_id = db.Column(db.Integer, db.ForeignKey('users.id'), nullable=False)
    token_id = db.Column(db.Integer, db.ForeignKey('tokens.id'), nullable=True)
    token = relationship('Token')

    created_at = db.Column(db.DateTime(timezone=True),
                           nullable=False,
                           default=datetime.now)
    updated_at = db.Column(db.DateTime(timezone=True), nullable=True)
Example #10
0
class Scrobble(db.Model, BaseScrobble):
    __tablename__ = 'scrobbles'

    created_at = db.Column(db.DateTime(timezone=True),
                           nullable=False,
                           default=datetime.now)
    source = db.Column(db.String(255))
    rating = db.Column(db.String(255))
    artist_id = db.Column(db.Integer,
                          db.ForeignKey('artists.id'),
                          nullable=True)
    album_id = db.Column(db.Integer, db.ForeignKey('albums.id'), nullable=True)
    token_id = db.Column(db.Integer, db.ForeignKey('tokens.id'), nullable=True)
    token = relationship('Token')

    def __repr__(self):
        return "<Scrobble #{id}: {artist} - {track}>".format(
            id=self.id, artist=self.artist, track=self.track)
Example #11
0
class User(db.Model):
    __tablename__ = 'users'

    id = db.Column(db.Integer, primary_key=True)
    created_at = db.Column(db.DateTime(timezone=True),
                           nullable=False,
                           default=datetime.now)
    username = db.Column(db.String(32), unique=True)
    email = db.Column(db.String(255), unique=True)
    _api_password = db.Column('api_password', db.String(32))
    _webui_password = db.Column('webui_password', db.String(128))
    is_active = db.Column(db.Boolean, default=True, nullable=False)
    sessions = db.relationship('Session', backref='user')
    tokens = db.relationship(
        'Token',
        backref='user',
        primaryjoin="and_(Token.user_id == User.id, Token.is_active)",
    )

    @hybrid_property
    def api_password(self):
        return self._api_password

    @api_password.setter
    def _set_api_password(self, data):
        self._api_password = md5(data)

    @hybrid_property
    def webui_password(self):
        return self._webui_password

    @webui_password.setter
    def _set_webui_password(self, data):
        self._webui_password = bcrypt.generate_password_hash(data).decode(
            'utf-8')

    def validate_api_password(self, data):
        return self.api_password == md5(data)

    def validate_webui_password(self, data):
        try:
            return bcrypt.check_password_hash(self.webui_password, data)
        except ValueError:
            return False

    @property
    def is_authenticated(self):
        return True

    @property
    def is_anonymous(self):
        return False

    def get_id(self):
        return "{}".format(self.id)

    def __str__(self):
        return self.username

    def __repr__(self):
        return "<User {username}>".format(username=self.username)
Example #12
0
class BaseCorrection(object):
    id = db.Column(db.Integer, primary_key=True)
    old = db.Column(db.String(255), nullable=False)
    new = db.Column(db.String(255), nullable=False)
Example #13
0
class BaseDiff(object):
    """
    This table contains the normalized results of string comparison algorightms.

    - Dn contains the normalized value for the original object names;
    - DnL contains the normalized value for the lowercased object names.

    Each Dn field (D1, D2, D3 etc.) uses different algorithms (ifast_comp, Levenshtein, etc.).
    """

    ignore = db.Column(db.Boolean, default=False, nullable=False)

    # distance.ifast_comp()
    D1 = db.Column(db.Float)
    D1L = db.Column(db.Float)

    # distance.levenshtein()
    D2 = db.Column(db.Float)
    D2L = db.Column(db.Float)

    # distance.sorensen()
    D3 = db.Column(db.Float)
    D3L = db.Column(db.Float)

    # distance.jaccard()
    D4 = db.Column(db.Float)
    D4L = db.Column(db.Float)

    # distance.hamming()
    D5 = db.Column(db.Float)
    D5L = db.Column(db.Float)
Example #14
0
 def user_id(cls):
     return db.Column(db.Integer, db.ForeignKey('users.id'), nullable=False)