# encoding=utf8 # 储存数据库模型 from . import db from datetime import datetime from . import ModelView import json from typing import Union,Optional from pydantic import BaseModel default_header = { "User-Agent": "Mozilla/5.0 (Linux; U; Android 10; zh-cn; Mi 10 Build/QKQ1.191117.002) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/79.0.3945.147 Mobile Safari/537.36 XiaoMi/MiuiBrowser/13.5.40" } class ApisModelVies(ModelView): create_template = 'api_edit.html' edit_template = 'api_edit.html' # 在当前页面编辑 # create_modal = True # edit_modal = True # 启用搜索 column_searchable_list = ['desc'] # 可以导出 csv can_export = True class Apis(db.Model): id = db.Column(db.Integer, primary_key=True) # 主键 desc = db.Column(db.String(20), default="Default") # 描述 url = db.Column(db.String(9999), unique=True, nullable=False) # 链接 method = db.Column(db.Enum("GET","POST"), nullable=False) # 请求方法 header = db.Column(db.String(9999)) # 请求头 data = db.Column(db.String(9999)) # 请求数据 add_time = db.Column(db.DateTime(), default=datetime.now) # 添加时间 class API(BaseModel): desc: str = "Default" url: str method: str = "GET" header: Optional[Union[str, dict]] = default_header data: Optional[Union[str, dict]] def replace_data(self, content: Union[str, dict], phone) -> str: # 统一转换成 str 再替换. content = str(content).replace("[phone]", phone).replace( "[timestamp]", self.timestamp_new()).replace("'",'"') # 尝试 json 化 try: return json.loads(content) except: return content def timestamp_new(self) -> str: """返回整数字符串时间戳""" return str(int(datetime.now().timestamp())) def handle_API(self, phone=None): """ :param API: one API basemodel :return: API basemodel """ if isinstance(self.header, str) and self.header: self.header = self.replace_data(self.header, phone) self.data = self.replace_data(self.data, phone) self.url = self.replace_data(self.url, phone) return self