class Project(db.Model): id = db.Column(db.Integer, primary_key=True) title = db.Column(db.String(50), unique=True, nullable=False) code = db.Column(db.String(50), nullable=True) desc = db.Column(db.Text, nullable=False) status = db.Column(db.Integer, nullable=True, default=0) guide_id = db.Column(db.Integer, db.ForeignKey('guide.id'), nullable=True) external_id = db.Column(db.Integer, db.ForeignKey('guide.id'), nullable=True) team_id = db.Column(db.Integer, db.ForeignKey('team.id'), nullable=True) techUsed = db.Column(db.Text, nullable=True) date_created = db.Column(db.DateTime, nullable=False, default=datetime.now() + timedelta(hours=5, minutes=30)) ext_relation = db.relationship('Guide', foreign_keys=[external_id], backref='external') int_relation = db.relationship('Guide', foreign_keys=[guide_id], backref='mentor') # projectDemo = db.relationship('ProjectGuideDemo', backref="projectDemoDetails", lazy=True) def __repr__(self): return f"Project('{self.title}', '{self.status}', '{self.guide_id}', '{self.date_created}' )"
class User(db.Model, UserMixin): id = db.Column(db.Integer, primary_key=True) username = db.Column(db.String(20), unique=True, nullable=False) email = db.Column(db.String(120), unique=True, nullable=False) image_file = db.Column(db.String(20), nullable=False, default='default.jpg') password = db.Column(db.String(60), nullable=False) posts = db.relationship('Post', backref='author', lazy=True) def get_reset_token(self, expires_sec=1800): s = Serializer(current_app.config['SECRET_KEY'], expires_sec) return s.dumps({'user_id': self.id}).decode('utf-8') @staticmethod def verify_reset_token(token): s = Serializer(current_app.config['SECRET_KEY']) try: user_id = s.loads(token)['user_id'] except: return None return User.query.get(user_id) def __repr__(self): return f"User('{self.username}', '{self.email}', '{self.image_file}')"
class User(db.Model,UserMixin): id = db.Column(db.Integer,primary_key=True) username = db.Column(db.String(20),unique=True,nullable=False) email = db.Column(db.String(120), unique=True, nullable=False) image_file = db.Column(db.String(20), nullable=False, default='default.jpg') password = db.Column(db.String(60), nullable=False) def __repr__(self): return f"User('{self.username}', '{self.email}', '{self.image_file}')"
class Student(db.Model): id = db.Column(db.Integer, primary_key=True) team_id = db.Column(db.Integer, db.ForeignKey('team.id'), nullable=True) name = db.Column(db.String(50), nullable=False) email = db.Column(db.String(120), nullable=False) phone = db.Column(db.String(10), nullable=False) cls = db.Column(db.String(7), nullable=False) def __repr__(self): return f"Student('{self.name}', '{self.email}', '{self.phone}', '{self.cls}')"
class Guide(db.Model, UserMixin): id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String(50), nullable=False) email = db.Column(db.String(120), nullable=False, unique=True) username = db.Column(db.String(8), nullable=False, unique=True) password = db.Column(db.String(8), nullable=False) # guideDemo = db.relationship('ProjectGuideDemo', backref="guideDemoDetails", lazy=True) def __repr__(self): return f"Guide('{self.name}', '{self.email}', '{self.interest}')"
class Guide(db.Model, UserMixin): id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String(50), nullable=False) email = db.Column(db.String(120), nullable=False) # unique=True <- Put this in email field username = db.Column(db.String(8), nullable=False) password = db.Column(db.String(8), nullable=False) interest = db.Column(db.Text, nullable=False) projects = db.relationship('Project', backref='mentor', lazy=True) def __repr__(self): return f"Guide('{self.name}', '{self.email}', '{self.interest}')"
class Visit(db.Model): id = db.Column(db.Integer, primary_key=True, nullable=False, unique=True) bookerId = db.Column(db.Integer, db.ForeignKey('user.id')) doctorId = db.Column(db.Integer, nullable=False) date = db.Column(db.String(20), nullable=False) startTime = db.Column(db.String(20), nullable=False) diganosis = db.Column(db.String(600), nullable=False, default = 'Brak diagnozy') recommendations = db.Column(db.String(600), nullable=False, default = 'Brak zaleceń') def __repr__(self): return f"Visit('{self.id}', '{self.date}', '{self.startTime}')"
class Project(db.Model): id = db.Column(db.Integer, primary_key=True) title = db.Column(db.String(50), unique=True, nullable=False) code = db.Column(db.String(50), nullable=True) desc = db.Column(db.Text, nullable=False) status = db.Column(db.String(20), nullable=True, default='NotPublished') guide_id = db.Column(db.Integer, db.ForeignKey('guide.id'), nullable=True) team_id = db.Column(db.Integer, db.ForeignKey('team.id'), nullable=True) techUsed = db.Column(db.Text, nullable=True) reason = db.Column(db.Text, nullable=False) date_created = db.Column(db.DateTime, nullable=False, default=datetime.utcnow) def __repr__(self): return f"Project('{self.title}', '{self.leader}', '{self.status}', '{self.guide_id}', '{self.date_created}')"
class todo(db.Model): id = db.Column(db.Integer, primary_key=True) content = db.Column(db.String(200), nullable=False) data_created = db.Column(db.DateTime, default=datetime.utcnow) def __repr__(self, content, data_created): return '<Task %i>' % self.id
class Team(db.Model): id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String(50), nullable=False) members = db.relationship('Student', backref='team', lazy=True) project_team = db.relationship('Project', backref='team', lazy=True) def __repr__(self): return f"Team('{self.name}')"
class User(db.Model, UserMixin): id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String(25), nullable=False) surname = db.Column(db.String(35), nullable=False) email = db.Column(db.String(120), unique=True, nullable=False) password = db.Column(db.String(60), nullable=False) phoneNumber = db.Column(db.Integer, nullable=False) userType = db.Column(db.String(20), default = 'user') def isDoctor(self): if self.userType == 'doctor': return True else: return False def __repr__(self): return f"User('{self.email}', '{self.name}', '{self.surname}')"
class Post(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"Post('{self.title}', '{self.date_posted}')"