-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmodels.py
More file actions
40 lines (29 loc) · 1.13 KB
/
models.py
File metadata and controls
40 lines (29 loc) · 1.13 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
from sqlalchemy import Column, Integer, String,Boolean,DateTime, ForeignKey
from database import Base
from datetime import datetime
class User(Base):
__tablename__ = "users"
id = Column(Integer, primary_key=True, index=True)
name = Column(String)
email = Column(String, unique=True)
password = Column(String)
role = Column(String) # user / admin
#EXTRA
is_verified = Column(Boolean, default=False)
otp = Column(String, nullable=True)
otp_expiry = Column(DateTime, nullable=True)
#THIS IS FOR RESET PASSWORD
reset_token = Column(String, nullable=True)
reset_token_expiry = Column(DateTime, nullable=True)
class Event(Base):
__tablename__ = "events"
id = Column(Integer, primary_key=True, index=True)
title = Column(String)
date = Column(String)
location = Column(String)
class Registration(Base):
__tablename__ = "registrations"
id = Column(Integer, primary_key=True, index=True)
user_id = Column(Integer, ForeignKey("users.id"))
event_id = Column(Integer, ForeignKey("events.id"))
attended = Column(Boolean, default=False) # 🔥 ADD THIS