55 lines
1.9 KiB
Python
55 lines
1.9 KiB
Python
from datetime import datetime
|
|
from sqlalchemy import Column, Integer, String, Boolean, DateTime, ForeignKey, Text
|
|
from sqlalchemy.orm import relationship
|
|
|
|
from app.core.database import Base
|
|
|
|
|
|
class Dept(Base):
|
|
__tablename__ = "sys_dept"
|
|
|
|
id = Column(Integer, primary_key=True, index=True)
|
|
name = Column(String(100), nullable=False)
|
|
parent_id = Column(Integer, ForeignKey("sys_dept.id"), nullable=True)
|
|
sort_order = Column(Integer, default=0)
|
|
created_at = Column(DateTime, default=datetime.utcnow)
|
|
|
|
parent = relationship("Dept", remote_side=[id], backref="children")
|
|
|
|
|
|
class Role(Base):
|
|
__tablename__ = "sys_role"
|
|
|
|
id = Column(Integer, primary_key=True, index=True)
|
|
name = Column(String(50), unique=True, nullable=False)
|
|
code = Column(String(50), unique=True, nullable=False)
|
|
description = Column(String(200))
|
|
created_at = Column(DateTime, default=datetime.utcnow)
|
|
|
|
|
|
class User(Base):
|
|
__tablename__ = "sys_user"
|
|
|
|
id = Column(Integer, primary_key=True, index=True)
|
|
username = Column(String(50), unique=True, nullable=False, index=True)
|
|
email = Column(String(100), unique=True, nullable=True)
|
|
hashed_password = Column(String(255), nullable=False)
|
|
real_name = Column(String(50))
|
|
phone = Column(String(20))
|
|
is_active = Column(Boolean, default=True)
|
|
is_superuser = Column(Boolean, default=False)
|
|
dept_id = Column(Integer, ForeignKey("sys_dept.id"), nullable=True)
|
|
created_at = Column(DateTime, default=datetime.utcnow)
|
|
updated_at = Column(DateTime, default=datetime.utcnow, onupdate=datetime.utcnow)
|
|
|
|
dept = relationship("Dept")
|
|
roles = relationship("Role", secondary="sys_user_role", backref="users")
|
|
|
|
|
|
class UserRole(Base):
|
|
__tablename__ = "sys_user_role"
|
|
|
|
id = Column(Integer, primary_key=True, index=True)
|
|
user_id = Column(Integer, ForeignKey("sys_user.id"), nullable=False)
|
|
role_id = Column(Integer, ForeignKey("sys_role.id"), nullable=False)
|