示例#1
0
class MessMenu(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    user_id = db.Column(db.Integer, db.ForeignKey('user.id'), nullable=False)
    type_of_meal = db.Column(db.String(100), nullable=False)
    menu = db.Column(db.Text, nullable=False)
    image = db.Column(db.String(20), nullable=False, default='food.jpg')
    date_posted = db.Column(db.DateTime,
                            nullable=False,
                            default=datetime.utcnow)

    def __repr__(self):
        return f"MessMenu('{self.type_of_meal}', '{self.date_posted}')"
示例#2
0
class Complaint(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String(100), nullable=False)
    date_posted = db.Column(db.DateTime,
                            nullable=False,
                            default=datetime.utcnow)
    content = db.Column(db.Text, nullable=False)
    user_id = db.Column(db.Integer, db.ForeignKey('user.id'), nullable=False)
    status = db.Column(db.String(20), nullable=False, default="Unresolved")
    answers = db.relationship('Answer', backref='complaint', lazy=True)

    def __repr__(self):
        return f"Complaint('{self.title}', '{self.date_posted}')"
示例#3
0
class Visitor(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(10), nullable=False)
    hostel_block = db.Column(db.String(1), nullable=False)
    room_no = db.Column(db.Integer, nullable=False)
    for_user_id = db.Column(db.Integer,
                            db.ForeignKey('user.id'),
                            nullable=False)
    status = db.Column(db.Integer, nullable=False, default=0)
    # 0 -> entered, 1-> exited
    datetime = db.Column(db.DateTime, nullable=False, default=datetime.utcnow)

    def __repr__(self):
        return f"Visitor('{self.name}', '{self.for_user_id}','{self.status}', '{self.datetime}')"
示例#4
0
class User(db.Model, UserMixin):
    id = db.Column(db.Integer, primary_key=True)
    college_id = db.Column(db.String(9), unique=True, nullable=False)
    firstname = db.Column(db.String(20), nullable=False)
    lastname = db.Column(db.String(20), nullable=False)
    email = db.Column(db.String(120), unique=True, nullable=False)
    password = db.Column(db.String(60), nullable=False)
    phone = db.Column(db.String(10), unique=True, nullable=False)
    address = db.Column(db.Text, nullable=False)
    course = db.Column(db.String(20), nullable=True)
    department = db.Column(db.String(20), nullable=True)
    user_type = db.Column(db.Integer, nullable=False, default=1)
    room_no = db.Column(db.Integer, nullable=True)
    #admin-0, student-1, guard-2, messstaff-3, CR-4
    announcements = db.relationship('Announcement',
                                    backref='author',
                                    lazy=True)
    complaints = db.relationship('Complaint', backref='author', lazy=True)
    mess_menu = db.relationship('MessMenu', backref='author', lazy=True)
    courier = db.relationship('Courier', backref='user', lazy=True)
    exitentry = db.relationship('ExitEntry', backref='user', lazy=True)
    visitor = db.relationship('Visitor', backref='user', lazy=True)

    def __repr__(self):
        return f"User('{self.college_id}', '{self.firstname}', '{self.lastname}')"
示例#5
0
class Announcement(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    title = db.Column(db.String(100), nullable=False)
    date_posted = db.Column(db.DateTime,
                            nullable=False,
                            default=datetime.utcnow)
    content = db.Column(db.Text, nullable=False)
    user_id = db.Column(db.Integer, db.ForeignKey('user.id'), nullable=False)

    def __repr__(self):
        return f"Announcement('{self.title}', '{self.date_posted}')"
示例#6
0
class Room(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    hostel_block = db.Column(db.String(1), nullable=False)
    room_no = db.Column(db.Integer, nullable=False)
    capacity = db.Column(db.Integer, nullable=False, default=3)
    student1_id = db.Column(db.Integer, nullable=True)
    student2_id = db.Column(db.Integer, nullable=True)
    student3_id = db.Column(db.Integer, nullable=True)

    def __repr__(self):
        return f"Room('{self.room_no}', '{self.hostel_block}')"
示例#7
0
class Courier(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    user_id = db.Column(db.Integer, db.ForeignKey('user.id'), nullable=False)
    from_name = db.Column(db.String(10), nullable=False)
    status = db.Column(db.Integer, nullable=False, default=0)
    # 0->arrived, 1->collected
    date_arrived = db.Column(db.DateTime,
                             nullable=False,
                             default=datetime.utcnow)

    def __repr__(self):
        return f"Courier('{self.room_no}', '{self.hostel}')"
示例#8
0
class Application(db.Model):
    id = db.Column(db.Integer, primary_key=True)
    college_id = db.Column(db.String(9), unique=True, nullable=False)
    firstname = db.Column(db.String(20), nullable=False)
    lastname = db.Column(db.String(20), nullable=False)
    email = db.Column(db.String(120), unique=True, nullable=False)
    phone = db.Column(db.String(10), unique=True, nullable=False)
    address = db.Column(db.Text, nullable=False)
    city = db.Column(db.String(10), nullable=False)
    income = db.Column(db.Integer, nullable=False)
    course = db.Column(db.String(20), nullable=False)
    department = db.Column(db.String(20), nullable=False)
    date_posted = db.Column(db.DateTime,
                            nullable=False,
                            default=datetime.utcnow)
    status = db.Column(db.Integer, nullable=False, default=0)

    #0-->pending 1-->alloted

    def __repr__(self):
        return f"Application('{self.college_id}', '{self.firstname}', '{self.lastname}')"