|
| 1 | +from typing import Literal |
| 2 | + |
| 3 | +from sqlalchemy import BigInteger, Boolean, Enum, ForeignKey, String |
| 4 | +from sqlalchemy.orm import Mapped, mapped_column, relationship |
| 5 | + |
| 6 | +from api.models.orm import Jam, Team, team_has_users_table |
| 7 | +from api.models.orm.base import Base |
| 8 | + |
| 9 | +ExperienceLevels = Literal["beginner", "decent", "expierienced", "very_expierienced"] |
| 10 | + |
| 11 | + |
| 12 | +class User(Base): |
| 13 | + """A user who has participated in a code jam.""" |
| 14 | + |
| 15 | + __tablename__ = "users" |
| 16 | + |
| 17 | + user_id: Mapped[int] = mapped_column(BigInteger, primary_key=True, autoincrement=False) |
| 18 | + |
| 19 | + teams: Mapped[list[Team]] = relationship( |
| 20 | + secondary=team_has_users_table, |
| 21 | + back_populates="users", |
| 22 | + ) |
| 23 | + jam_specific_details: Mapped[list["JamSpecificDetail"]] = relationship() |
| 24 | + |
| 25 | + |
| 26 | +class JamSpecificDetail(Base): |
| 27 | + """Jam specific details that a user fills for each code jam.""" |
| 28 | + |
| 29 | + __tablename__ = "jam_specific_details" |
| 30 | + |
| 31 | + jam_specific_detail_id: Mapped[int] = mapped_column(primary_key=True) |
| 32 | + user_id: Mapped[int] = mapped_column(ForeignKey(User.id)) |
| 33 | + jam_id: Mapped[int] = mapped_column(ForeignKey(Jam.jam_id)) |
| 34 | + experience_level_git: Mapped[ExperienceLevels] = mapped_column( |
| 35 | + Enum(*ExperienceLevels.__args__, name="experience_level_git_enum"), |
| 36 | + nullable=False, |
| 37 | + ) |
| 38 | + experience_level_python: Mapped[ExperienceLevels] = mapped_column( |
| 39 | + Enum(*ExperienceLevels.__args__, name="experience_level_python_enum"), |
| 40 | + nullable=False, |
| 41 | + ) |
| 42 | + time_zone: Mapped[str] = mapped_column(String()) |
| 43 | + willing_to_lead: Mapped[bool] = mapped_column(Boolean) |
| 44 | + |
| 45 | + user: Mapped[User] = relationship(back_populates="jam_specific_details") |
0 commit comments