#!/usr/bin/env python3 # -*- coding: utf-8 -*- from datetime import datetime from typing import Union from sqlalchemy import ForeignKey, String from sqlalchemy.orm import Mapped, mapped_column, relationship from backend.app.database.db_mysql import uuid4_str from backend.app.models.base import Base, id_key from backend.app.models.sys_user_role import sys_user_role from backend.app.utils.timezone import timezone class User(Base): """用户表""" __tablename__ = 'sys_user' id: Mapped[id_key] = mapped_column(init=False) uuid: Mapped[str] = mapped_column(String(50), init=False, default_factory=uuid4_str, unique=True) username: Mapped[str] = mapped_column(String(20), unique=True, index=True, comment='用户名') nickname: Mapped[str] = mapped_column(String(20), unique=True, comment='昵称') password: Mapped[str | None] = mapped_column(String(255), comment='密码') salt: Mapped[str | None] = mapped_column(String(5), comment='加密盐') email: Mapped[str] = mapped_column(String(50), unique=True, index=True, comment='邮箱') is_superuser: Mapped[bool] = mapped_column(default=False, comment='超级权限(0否 1是)') is_staff: Mapped[bool] = mapped_column(default=False, comment='后台管理登陆(0否 1是)') status: Mapped[int] = mapped_column(default=1, comment='用户账号状态(0停用 1正常)') is_multi_login: Mapped[bool] = mapped_column(default=False, comment='是否重复登陆(0否 1是)') avatar: Mapped[str | None] = mapped_column(String(255), default=None, comment='头像') phone: Mapped[str | None] = mapped_column(String(11), default=None, comment='手机号') join_time: Mapped[datetime] = mapped_column(init=False, default_factory=timezone.now, comment='注册时间') last_login_time: Mapped[datetime | None] = mapped_column(init=False, onupdate=timezone.now, comment='上次登录') # 部门用户一对多 dept_id: Mapped[int | None] = mapped_column( ForeignKey('sys_dept.id', ondelete='SET NULL'), default=None, comment='部门关联ID' ) dept: Mapped[Union['Dept', None]] = relationship(init=False, back_populates='users') # noqa: F821 # 用户角色多对多 roles: Mapped[list['Role']] = relationship( # noqa: F821 init=False, secondary=sys_user_role, back_populates='users' ) # 用户 OAuth2 一对多 socials: Mapped[list['UserSocial']] = relationship(init=False, back_populates='user') # noqa: F821