Files
LocalNav/models.py
T
dekun fd5e333daf feat: 服务管理支持 HTTP/HTTPS 协议选择
- Service 增加 scheme 字段,build_url 按协议拼接地址
- 表单新增协议下拉;启动时自动迁移已有 SQLite 库
- 更新部署说明中的 HTTPS 服务添加示例

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-05-30 11:37:32 +08:00

59 lines
1.9 KiB
Python

from flask_sqlalchemy import SQLAlchemy
from flask_login import UserMixin
from werkzeug.security import generate_password_hash, check_password_hash
db = SQLAlchemy()
class User(UserMixin, db.Model):
__tablename__ = "users"
id = db.Column(db.Integer, primary_key=True)
username = db.Column(db.String(80), unique=True, nullable=False, index=True)
password_hash = db.Column(db.String(256), nullable=False)
def set_password(self, password: str) -> None:
self.password_hash = generate_password_hash(password)
def check_password(self, password: str) -> bool:
return check_password_hash(self.password_hash, password)
class ServiceGroup(db.Model):
__tablename__ = "service_groups"
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(120), nullable=False)
sort_order = db.Column(db.Integer, nullable=False, default=0)
services = db.relationship(
"Service",
backref="group",
lazy="dynamic",
cascade="all, delete-orphan",
)
class Service(db.Model):
__tablename__ = "services"
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(120), nullable=False)
scheme = db.Column(db.String(8), nullable=False, default="http")
host = db.Column(db.String(255), nullable=False)
port = db.Column(db.Integer, nullable=False)
path = db.Column(db.String(512), nullable=False, default="/")
sort_order = db.Column(db.Integer, nullable=False, default=0)
group_id = db.Column(
db.Integer, db.ForeignKey("service_groups.id"), nullable=False, index=True
)
def build_url(self) -> str:
p = (self.path or "/").strip()
if not p.startswith("/"):
p = "/" + p
proto = (self.scheme or "http").strip().lower()
if proto not in ("http", "https"):
proto = "http"
return f"{proto}://{self.host}:{self.port}{p}"