You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
orquestrador/admin_app/db/models/staff_account.py

49 lines
1.5 KiB
Python

from __future__ import annotations
from datetime import datetime
from sqlalchemy import Boolean, DateTime, Integer, String
from sqlalchemy.orm import Mapped, mapped_column
from sqlalchemy.types import TypeDecorator
from admin_app.db.models.base import AdminTimestampedModel
from shared.contracts import StaffRole, normalize_staff_role
# Modelo da conta administrativa
# Ele representa o usuario interno do painel.
class StaffRoleType(TypeDecorator):
impl = String(32)
cache_ok = True
@property
def python_type(self):
return StaffRole
def process_bind_param(self, value, dialect):
if value is None:
return None
return normalize_staff_role(value).value
def process_result_value(self, value, dialect):
if value is None:
return None
return normalize_staff_role(value)
class StaffAccount(AdminTimestampedModel):
__tablename__ = "staff_accounts"
id: Mapped[int] = mapped_column(Integer, primary_key=True, autoincrement=True)
email: Mapped[str] = mapped_column(String(255), unique=True, index=True, nullable=False)
display_name: Mapped[str] = mapped_column(String(150), nullable=False)
password_hash: Mapped[str] = mapped_column(String(255), nullable=False)
role: Mapped[StaffRole] = mapped_column(
StaffRoleType(),
nullable=False,
default=StaffRole.COLABORADOR,
)
is_active: Mapped[bool] = mapped_column(Boolean, nullable=False, default=True)
last_login_at: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)