2023-02-06 18:43:12 -09:00
|
|
|
from typing import TYPE_CHECKING, Optional
|
|
|
|
|
|
|
|
|
|
from sqlalchemy import ForeignKey, Integer, String, orm
|
|
|
|
|
from sqlalchemy.orm import Mapped, mapped_column
|
2021-09-09 08:51:29 -08:00
|
|
|
|
|
|
|
|
from .._model_base import BaseMixins, SqlAlchemyBase
|
2024-07-08 16:12:20 -05:00
|
|
|
from .._model_utils import guid
|
|
|
|
|
from .._model_utils.auto_init import auto_init
|
2021-09-09 08:51:29 -08:00
|
|
|
|
2023-02-06 18:43:12 -09:00
|
|
|
if TYPE_CHECKING:
|
2024-08-22 10:14:32 -05:00
|
|
|
from ..group import Group
|
|
|
|
|
from .household import Household
|
2023-02-06 18:43:12 -09:00
|
|
|
|
2021-09-09 08:51:29 -08:00
|
|
|
|
|
|
|
|
class GroupInviteToken(SqlAlchemyBase, BaseMixins):
|
|
|
|
|
__tablename__ = "invite_tokens"
|
2023-02-06 18:43:12 -09:00
|
|
|
token: Mapped[str] = mapped_column(String, index=True, nullable=False, unique=True)
|
|
|
|
|
uses_left: Mapped[int] = mapped_column(Integer, nullable=False, default=1)
|
2021-09-09 08:51:29 -08:00
|
|
|
|
2023-02-11 20:40:53 +01:00
|
|
|
group_id: Mapped[guid.GUID | None] = mapped_column(guid.GUID, ForeignKey("groups.id"), index=True)
|
2023-02-06 18:43:12 -09:00
|
|
|
group: Mapped[Optional["Group"]] = orm.relationship("Group", back_populates="invite_tokens")
|
2024-08-22 10:14:32 -05:00
|
|
|
household_id: Mapped[guid.GUID | None] = mapped_column(guid.GUID, ForeignKey("households.id"), index=True)
|
|
|
|
|
household: Mapped[Optional["Household"]] = orm.relationship("Household", back_populates="invite_tokens")
|
2021-09-09 08:51:29 -08:00
|
|
|
|
|
|
|
|
@auto_init()
|
|
|
|
|
def __init__(self, **_):
|
|
|
|
|
pass
|