Beispiel #1
0
class Movie(db.Model):
    __tablename__ = 'movies'
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(255), nullable=False)
    imdb_score = db.Column(db.Float)
    popularity = db.Column(db.Float)
    director_id = db.Column(db.Integer,
                            db.ForeignKey('directors.id'),
                            nullable=False)

    def __str__(self):
        return self.name

    def __repr__(self):
        return self.name

    def save(self):
        db.session.add(self)
        db.session.commit()
        return self

    @property
    def serialize(self):
        return {
            'id': self.id,
            'name': self.name,
            'imdb_score': self.imdb_score,
            '99popularity': self.popularity,
            'director': self.director.name,
            'genres': [genre.name for genre in self.genres]
        }
Beispiel #2
0
class GenreMovie(db.Model):
    __tablename__ = 'genre_movies'
    movie_id = db.Column(db.Integer,
                         db.ForeignKey('movies.id'),
                         nullable=False,
                         primary_key=True)
    genre_id = db.Column(db.Integer,
                         db.ForeignKey('genres.id'),
                         nullable=False,
                         primary_key=True)

    def save(self):
        db.session.add(self)
        db.session.commit()
        return self
Beispiel #3
0
class User(db.Model):
    __tablename__ = 'users'
    id = db.Column(db.Integer, primary_key=True)
    email = db.Column(db.String(50), unique=True)
    password = db.Column(db.String(255))
    first_name = db.Column(db.String(30), nullable=False)
    last_name = db.Column(db.String(30), nullable=False)
    is_active = db.Column(db.Boolean, nullable=False, default=False)
    is_super = db.Column(db.Boolean, nullable=False, default=False)
    is_admin = db.Column(db.Boolean, nullable=False, default=False)
    created_at = db.Column(db.DateTime, nullable=False, default=datetime.now)
    updated_at = db.Column(db.DateTime, nullable=False, default=datetime.now, onupdate=datetime.now)

    def __init__(self, _email=None, _password=None, _first_name='', _last_name=''):
        self.email = _email if _email else None
        if _password:
            self.password = _password
            self.set_password()
        self.first_name = _first_name.strip()
        self.last_name = _last_name.strip()

    def __str__(self):
        return '{0} {1}: {2}'.format(self.first_name, self.last_name, self.email)

    def __repr__(self):
        return '{0} {1}: {2}'.format(self.first_name, self.last_name, self.email)

    def save(self):
        db.session.add(self)
        db.session.commit()
        return self

    @classmethod
    def find_user(cls, _email=None, _id=None):
        if _email:
            return cls.query.filter_by(email=_email).first()
        if _id:
            return cls.query.filter_by(id=_id).first()

    def set_password(self):
        self.password = generate_password_hash(self.password)
        return self.password

    def check_password(self, password):
        return check_password_hash(self.password, password)
Beispiel #4
0
class Director(db.Model):
    __tablename__ = 'directors'
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(255), nullable=False)
    movies = db.relationship('Movie',
                             backref=backref('director', lazy='joined'),
                             lazy='dynamic')

    def __str__(self):
        return self.name

    def __repr__(self):
        return self.name

    def save(self):
        db.session.add(self)
        db.session.commit()
        return self