core/orm/invite.py

26 lines
743 B
Python
Raw Normal View History

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-02-21 16:14:58 +00:00
PENDING = 'PENDING'
ACCEPTED = 'ACCEPTED'
REJECTED = 'REJECTED'
2023-11-28 10:46:06 +00:00
class Invite(Base):
2024-02-21 16:14:58 +00:00
__tablename__ = 'invite'
2023-11-28 10:46:06 +00:00
2024-02-21 16:14:58 +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-21 16:14:58 +00:00
inviter = relationship('author', foreign_keys=[inviter_id])
author = relationship('author', foreign_keys=[author_id])
shout = relationship('shout')