model.py 1.5 KB

123456789101112131415161718192021222324252627282930
  1. # -*- coding: utf-8 -*-
  2. from sqlalchemy import String, Integer, Text
  3. from sqlalchemy.orm import Mapped, mapped_column
  4. from app.core.base_model import ModelMixin, UserMixin
  5. class OperationLogModel(ModelMixin, UserMixin):
  6. """
  7. 系统日志模型
  8. 日志类型:
  9. - 1: 登录日志
  10. - 2: 操作日志
  11. """
  12. __tablename__: str = "sys_log"
  13. __table_args__: dict[str, str] = ({'comment': '系统日志表'})
  14. __loader_options__: list[str] = ["created_by", "updated_by"]
  15. type: Mapped[int] = mapped_column(Integer, comment="日志类型(1登录日志 2操作日志)")
  16. request_path: Mapped[str] = mapped_column(String(255), comment="请求路径")
  17. request_method: Mapped[str] = mapped_column(String(10), comment="请求方式")
  18. request_payload: Mapped[str | None] = mapped_column(Text, comment="请求体")
  19. request_ip: Mapped[str | None] = mapped_column(String(50), comment="请求IP地址")
  20. login_location: Mapped[str | None] = mapped_column(String(255), comment="登录位置")
  21. request_os: Mapped[str | None] = mapped_column(String(64), nullable=True, comment="操作系统")
  22. request_browser: Mapped[str | None] = mapped_column(String(64), nullable=True, comment="浏览器")
  23. response_code: Mapped[int] = mapped_column(Integer, comment="响应状态码")
  24. response_json: Mapped[str | None] = mapped_column(Text, nullable=True, comment="响应体")
  25. process_time: Mapped[str | None] = mapped_column(String(20), nullable=True, comment="处理时间")