Files
PerToolBoxServer/backend/models.py
2026-03-31 16:03:55 +08:00

59 lines
2.1 KiB
Python

#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
PerToolBox Server - 数据模型
Copyright (C) 2024 Sea Network Technology Studio
Author: Canglan <admin@sea-studio.top>
License: AGPL v3
"""
from sqlalchemy import Column, Integer, String, Boolean, DateTime, Text, JSON
from sqlalchemy.sql import func
from .database import Base
class User(Base):
__tablename__ = "users"
id = Column(Integer, primary_key=True, index=True)
username = Column(String(50), unique=True, nullable=True)
phone = Column(String(20), unique=True, nullable=True)
email = Column(String(100), unique=True, nullable=True)
wx_openid = Column(String(100), unique=True, nullable=True)
password_hash = Column(String(200), nullable=False)
avatar = Column(String(500), nullable=True)
is_active = Column(Boolean, default=True)
created_at = Column(DateTime, server_default=func.now())
last_login = Column(DateTime, onupdate=func.now())
class Todo(Base):
__tablename__ = "todos"
id = Column(Integer, primary_key=True, index=True)
user_id = Column(Integer, nullable=False, index=True)
title = Column(String(200), nullable=False)
description = Column(Text, nullable=True)
completed = Column(Boolean, default=False)
priority = Column(Integer, default=1)
category = Column(String(50), default="学习")
due_date = Column(DateTime, nullable=True)
created_at = Column(DateTime, server_default=func.now())
updated_at = Column(DateTime, onupdate=func.now())
class Note(Base):
__tablename__ = "notes"
id = Column(Integer, primary_key=True, index=True)
user_id = Column(Integer, nullable=False, index=True)
title = Column(String(200), nullable=False)
content = Column(Text, nullable=True)
tags = Column(JSON, default=list)
is_archived = Column(Boolean, default=False)
created_at = Column(DateTime, server_default=func.now())
updated_at = Column(DateTime, onupdate=func.now())
class ToolStatsTotal(Base):
__tablename__ = "tool_stats_total"
id = Column(Integer, primary_key=True, index=True)
tool_name = Column(String(50), unique=True, nullable=False)
total_count = Column(Integer, default=0)