示例#1
0
class Review(db.Model):
    """Create table reviews
    One-to-Many relationship with user and business
    review belongs to business
    review belongs to user
    """
    __tablename__ = 'reviews'

    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    title = db.Column(db.String())
    desc = db.Column(db.String())
    user_id = db.Column(db.Integer, db.ForeignKey('users.id'), nullable=False)
    created_at = db.Column(db.DateTime, default=db.func.current_timestamp())
    updated_at = db.Column(db.DateTime,
                           default=db.func.current_timestamp(),
                           onupdate=db.func.current_timestamp())
    business_id = db.Column(db.Integer,
                            db.ForeignKey('businesses.id'),
                            nullable=False)

    def __init__(self, title, desc, business, reviewer):
        self.title = title
        self.desc = desc
        self.business = business
        self.reviewer = reviewer

    def save(self):
        """Save a review to the database"""
        db.session.add(self)
        db.session.commit()

    def delete(self):
        """Delete a given review."""
        db.session.delete(self)
        db.session.commit()
示例#2
0
class Entry(db.Model):
    """Create table entries
    One-to-Many relationship with user and diary
    entry belongs to diary
    entry belongs to user
    """
    __tablename__ = 'entries'

    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    title = db.Column(db.String())
    desc = db.Column(db.String())
    user_id = db.Column(db.Integer, db.ForeignKey('users.id'), nullable=False)
    created_at = db.Column(db.DateTime, default=db.func.current_timestamp())
    updated_at = db.Column(db.DateTime,
                           default=db.func.current_timestamp(),
                           onupdate=db.func.current_timestamp())
    diary_id = db.Column(db.Integer,
                         db.ForeignKey('diaries.id'),
                         nullable=False)

    def __init__(self, title, desc, diary, entryer):
        self.title = title
        self.desc = desc
        self.diary = diary
        self.entryer = entryer

    def save(self):
        """Save a entry to the database"""
        db.session.add(self)
        db.session.commit()

    def delete(self):
        """Delete a given entry."""
        db.session.delete(self)
        db.session.commit()
示例#3
0
class Notification(db.Model):
    """Handles notifications when user reviews on a business"""
    __tablename__ = 'notifications'

    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    recipient_id = db.Column(db.Integer,
                             db.ForeignKey('users.id'),
                             nullable=False)
    actor = db.Column(db.String(), nullable=False)
    business_id = db.Column(db.Integer, nullable=False)
    review_id = db.Column(db.Integer, nullable=False)
    action = db.Column(db.String(), nullable=False)
    read_at = db.Column(db.DateTime)
    created_at = db.Column(db.DateTime, default=db.func.current_timestamp())

    def __init__(self, recipient, actor, business_id, review_id, read_at=None):
        self.recipient = recipient
        self.actor = actor
        self.business_id = business_id
        self.review_id = review_id
        self.read_at = read_at
        self.action = ' reviewed one of your businesses'

    def save(self):
        """Save a review to the database"""
        db.session.add(self)
        db.session.commit()
示例#4
0
class Business(db.Model):
    """Create table businesses
    One-to-Many relationship with review and user
    business belongs to user
    business has many reviews
    """
    __tablename__ = 'businesses'

    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    name = db.Column(db.String(), index=True)
    logo = db.Column(db.String())
    location = db.Column(db.String(), index=True)
    category = db.Column(db.String(), index=True)
    bio = db.Column(db.String())
    user_id = db.Column(db.Integer, db.ForeignKey('users.id'), nullable=False)
    created_at = db.Column(db.DateTime, default=db.func.current_timestamp())
    updated_at = db.Column(db.DateTime,
                           default=db.func.current_timestamp(),
                           onupdate=db.func.current_timestamp())
    reviews = db.relationship('Review',
                              backref='business',
                              cascade='all, delete-orphan')

    def __init__(self,
                 name=None,
                 logo=None,
                 location=None,
                 category=None,
                 bio=None,
                 owner=None):
        self.name = name
        self.logo = logo
        self.location = location
        self.category = category
        self.bio = bio
        self.owner = owner

    def Search(self, params):
        """Search and filter"""
        page = params['page']
        limit = params['limit']
        location = params['location']
        category = params['category']
        _query = params['_query']

        if _query or location or category:
            if location and _query and not category:
                return self.query.filter(
                    Business.location == location,
                    Business.name.ilike('%' + _query + '%')).paginate(
                        page, limit, error_out=False).items

            if category and _query and not location:
                return self.query.filter(
                    Business.category == category,
                    Business.name.ilike('%' + _query + '%')).paginate(
                        page, limit, error_out=False).items

            if category and location and not _query:
                return self.query.filter(
                    Business.location == location,
                    Business.category == category).paginate(
                        page, limit, error_out=False).items

            if location and not _query and not category:
                return self.query.filter(
                    Business.location == location).paginate(
                        page, limit, error_out=False).items

            if category and not _query and not location:
                return self.query.filter(
                    Business.category == category).paginate(
                        page, limit, error_out=False).items

            return self.query.filter(
                Business.name.ilike('%' + _query + '%')).paginate(
                    page, limit, error_out=False).items

        return self.query.order_by(Business.created_at.desc()).paginate(
            page, limit, error_out=False).items

    def save(self):
        """Save a business to the database"""
        db.session.add(self)
        db.session.commit()

    def delete(self):
        """Delete a given business"""
        db.session.delete(self)
        db.session.commit()