2023-12-17 20:30:20 +00:00
|
|
|
from enum import Enum as Enumeration
|
|
|
|
|
|
|
|
from sqlalchemy import Column, ForeignKey, String
|
2023-11-28 10:46:06 +00:00
|
|
|
from sqlalchemy.orm import relationship
|
2023-12-17 20:30:20 +00:00
|
|
|
|
|
|
|
from services.db import Base
|
2023-11-28 10:46:06 +00:00
|
|
|
|
|
|
|
|
|
|
|
class InviteStatus(Enumeration):
|
2024-01-25 19:41:27 +00:00
|
|
|
PENDING = 'PENDING'
|
|
|
|
ACCEPTED = 'ACCEPTED'
|
|
|
|
REJECTED = 'REJECTED'
|
2023-11-28 10:46:06 +00:00
|
|
|
|
|
|
|
|
|
|
|
class Invite(Base):
|
2024-01-25 19:41:27 +00:00
|
|
|
__tablename__ = 'invite'
|
2023-11-28 10:46:06 +00:00
|
|
|
|
2024-02-20 08:53:55 +00:00
|
|
|
inviter_id = Column(ForeignKey('author.id'), primary_key=True)
|
|
|
|
author_id = Column(ForeignKey('author.id'), primary_key=True)
|
|
|
|
shout_id = Column(ForeignKey('shout.id'), primary_key=True)
|
2023-11-30 08:40:27 +00:00
|
|
|
status = Column(String, default=InviteStatus.PENDING.value)
|
2023-11-28 10:46:06 +00:00
|
|
|
|
2024-02-20 09:40:22 +00:00
|
|
|
inviter = relationship('author', foreign_keys=[inviter_id])
|
|
|
|
author = relationship('author', foreign_keys=[author_id])
|
|
|
|
shout = relationship('shout')
|