2023-10-26 20:38:31 +00:00
|
|
|
from base.orm import Base
|
2023-08-06 20:01:40 +00:00
|
|
|
from datetime import datetime
|
2023-10-26 17:56:42 +00:00
|
|
|
from enum import Enum as Enumeration
|
|
|
|
from sqlalchemy import Boolean, Column, DateTime, Enum, ForeignKey, Integer
|
2023-10-10 06:35:27 +00:00
|
|
|
from sqlalchemy.dialects.postgresql import JSONB
|
|
|
|
|
2023-10-09 10:52:13 +00:00
|
|
|
|
|
|
|
class NotificationType(Enumeration):
|
|
|
|
NEW_COMMENT = 1
|
|
|
|
NEW_REPLY = 2
|
2021-08-19 10:02:28 +00:00
|
|
|
|
2022-09-03 10:50:14 +00:00
|
|
|
|
2021-08-19 10:02:28 +00:00
|
|
|
class Notification(Base):
|
2022-09-03 10:50:14 +00:00
|
|
|
__tablename__ = "notification"
|
2021-08-19 10:02:28 +00:00
|
|
|
|
2023-10-09 10:52:13 +00:00
|
|
|
shout = Column(ForeignKey("shout.id"), index=True)
|
|
|
|
reaction = Column(ForeignKey("reaction.id"), index=True)
|
2023-08-06 20:01:40 +00:00
|
|
|
user = Column(ForeignKey("user.id"), index=True)
|
|
|
|
createdAt = Column(DateTime, nullable=False, default=datetime.now, index=True)
|
|
|
|
seen = Column(Boolean, nullable=False, default=False, index=True)
|
2023-10-09 10:52:13 +00:00
|
|
|
type = Column(Enum(NotificationType), nullable=False)
|
2023-10-10 06:35:27 +00:00
|
|
|
data = Column(JSONB, nullable=True)
|
2023-10-09 10:52:13 +00:00
|
|
|
occurrences = Column(Integer, default=1)
|