TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 1 | from flask import Blueprint, render_template |
| 2 | from .functions.Fpost import Fpost; |
| 3 | from sqlalchemy import create_engine |
| 4 | from sqlalchemy.orm import sessionmaker |
| 5 | from config import Config |
| 6 | from flask import jsonify,request |
| 7 | |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 8 | |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 9 | main = Blueprint('main', __name__) |
| 10 | |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 11 | |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 12 | @main.route('/sgiveadmin',methods=['POST','GET']) |
| 13 | def giveadmin(): |
| 14 | data=request.get_json() |
| 15 | print(data) |
| 16 | engine=create_engine(Config.SQLURL) |
| 17 | SessionLocal = sessionmaker(bind=engine) |
| 18 | session = SessionLocal() |
| 19 | f=Fpost(session) |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 20 | checres,userid=f.checkid(data['userid'],'superadmin') |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 21 | if(not checres): |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 22 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 23 | 'error', |
| 24 | '系统需要超级管理员才能执行修改用户角色的操作,但是当前用户不是超级管理员', |
| 25 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 26 | return jsonify({'status': 'error', 'message': 'Unauthorized'}) |
| 27 | |
| 28 | res=f.giveadmin(data['targetid']) |
| 29 | if not res: |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 30 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 31 | 'error', |
| 32 | f"尝试修改用户{data['targetid']}角色为admin失败,用户不存在", |
| 33 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 34 | return jsonify({'status': 'error', 'message': 'User not found'}) |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 35 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 36 | 'behavior', |
| 37 | f'用户角色为admin修改成功,用户ID: {data["targetid"]} 被修改为管理员', |
| 38 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 39 | return jsonify({'status': 'success', 'message': 'User role updated to admin'}) |
| 40 | |
| 41 | @main.route('/sgiveuser',methods=['POST','GET']) |
| 42 | def giveuser(): |
| 43 | data=request.get_json() |
| 44 | print(data) |
| 45 | engine=create_engine(Config.SQLURL) |
| 46 | SessionLocal = sessionmaker(bind=engine) |
| 47 | session = SessionLocal() |
| 48 | f=Fpost(session) |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 49 | checres,userid=f.checkid(data['userid'],'superadmin') |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 50 | if(not checres): |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 51 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 52 | 'error', |
| 53 | '系统需要超级管理员才能执行修改用户角色的操作,但是当前用户不是超级管理员', |
| 54 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 55 | return jsonify({'status': 'error', 'message': 'Unauthorized'}) |
| 56 | |
| 57 | res=f.giveuser(data['targetid']) |
| 58 | if not res: |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 59 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 60 | 'error', |
| 61 | f"尝试修改用户{data['targetid']}为user失败,用户不存在", |
| 62 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 63 | return jsonify({'status': 'error', 'message': 'User not found'}) |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 64 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 65 | 'behavior', |
| 66 | f'用户角色修改成功,用户ID: {data["targetid"]} 被修改为普通用户', |
| 67 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 68 | return jsonify({'status': 'success', 'message': 'User role updated to user'}) |
| 69 | |
| 70 | |
| 71 | @main.route('/sgivesuperadmin',methods=['POST','GET']) |
| 72 | def givesuperadmin(): |
| 73 | data=request.get_json() |
| 74 | print(data) |
| 75 | engine=create_engine(Config.SQLURL) |
| 76 | SessionLocal = sessionmaker(bind=engine) |
| 77 | session = SessionLocal() |
| 78 | f=Fpost(session) |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 79 | checres,userid=f.checkid(data['userid'],'superadmin') |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 80 | if(not checres): |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 81 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 82 | 'error', |
| 83 | '系统需要超级管理员才能执行修改用户角色的操作,但是当前用户不是超级管理员', |
| 84 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 85 | return jsonify({'status': 'error', 'message': 'Unauthorized'}) |
| 86 | |
| 87 | res=f.givesuperadmin(data['targetid']) |
| 88 | if not res: |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 89 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 90 | 'error', |
| 91 | f'尝试修改用户{data["targetid"]}角色为superadmin失败,用户不存在', |
| 92 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 93 | return jsonify({'status': 'error', 'message': 'User not found'}) |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 94 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 95 | 'behavior', |
| 96 | f'用户角色修改成功,用户ID: {data["targetid"]} 被修改为超级管理员', |
| 97 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 98 | return jsonify({'status': 'success', 'message': 'User role updated to superadmin'}) |
| 99 | |
| 100 | @main.route('/sgetuserlist',methods=['POST','GET']) |
| 101 | def userlist(): |
| 102 | data=request.get_json() |
| 103 | print(data) |
| 104 | engine=create_engine(Config.SQLURL) |
| 105 | SessionLocal = sessionmaker(bind=engine) |
| 106 | session = SessionLocal() |
| 107 | f=Fpost(session) |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 108 | checres,userid=f.checkid(data['userid'],'superadmin') |
| 109 | print("+++++++++++++++++++++++++++++++++++++++++++++++++") |
| 110 | print(checres) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 111 | if(not checres): |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 112 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 113 | 'error', |
| 114 | '系统需要超级管理员才能执行获取用户列表的操作,但是当前用户不是超级管理员', |
| 115 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 116 | return jsonify({'status': 'error', 'message': 'Unauthorized'}) |
| 117 | res=f.getuserlist() |
| 118 | respons=[] |
| 119 | for datai in res: |
| 120 | respons.append({ |
| 121 | 'id': datai[0], |
| 122 | 'username': datai[1], |
| 123 | 'role': datai[2] |
| 124 | }) |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 125 | |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 126 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 127 | 'access', |
| 128 | '获取用户列表成功', |
| 129 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 130 | return jsonify(respons) |
| 131 | |
| 132 | @main.route('/apostlist',methods=['POST','GET']) |
| 133 | def postlist(): |
| 134 | data=request.get_json() |
| 135 | print(data) |
| 136 | engine=create_engine(Config.SQLURL) |
| 137 | SessionLocal = sessionmaker(bind=engine) |
| 138 | session = SessionLocal() |
| 139 | f=Fpost(session) |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 140 | checres,userid=f.checkid(data['userid'],'admin') |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 141 | if(not checres): |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 142 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 143 | 'error', |
| 144 | '系统需要管理员才能执行获取帖子列表的操作,但是当前用户不是管理员', |
| 145 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 146 | return jsonify({'status': 'error', 'message': 'Unauthorized'}) |
| 147 | res=f.getlist() |
| 148 | respons=[] |
| 149 | for datai in res: |
| 150 | respons.append({ |
| 151 | 'id': datai[0], |
| 152 | 'title': datai[1], |
| 153 | 'status': datai[2] |
| 154 | }) |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 155 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 156 | 'access', |
| 157 | '获取帖子列表成功', |
| 158 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 159 | return jsonify(respons) |
| 160 | |
| 161 | @main.route('/agetpost',methods=['POST','GET']) |
| 162 | def post(): |
| 163 | data=request.get_json() |
| 164 | engine=create_engine(Config.SQLURL) |
| 165 | SessionLocal = sessionmaker(bind=engine) |
| 166 | session = SessionLocal() |
| 167 | f=Fpost(session) |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 168 | checres,userid=f.checkid(data['userid'],'admin') |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 169 | if(not checres): |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 170 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 171 | 'error', |
| 172 | '系统需要管理员才能执行获取帖子详情的操作,但是当前用户不是管理员', |
| 173 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 174 | return jsonify({'status': 'error', 'message': 'Unauthorized'}) |
| 175 | res=f.getpost(data['postid']) |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 176 | if not res: |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 177 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 178 | 'error', |
| 179 | f'尝试获取帖子{data["postid"]}失败,帖子不存在', |
| 180 | request.remote_addr) |
| 181 | return jsonify({'status': 'error', 'message': 'Post not found'}) |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 182 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 183 | 'access', |
| 184 | f'获取帖子详情成功,帖子ID: {data["postid"]}', |
| 185 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 186 | return jsonify(res.to_dict() if res else {}) |
| 187 | |
| 188 | @main.route('/areview',methods=['POST','GET']) |
| 189 | def review(): |
| 190 | data=request.get_json() |
| 191 | engine=create_engine(Config.SQLURL) |
| 192 | SessionLocal = sessionmaker(bind=engine) |
| 193 | session = SessionLocal() |
| 194 | f=Fpost(session) |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 195 | checres,userid=f.checkid(data['userid'],'admin') |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 196 | if(not checres): |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 197 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 198 | 'error', |
| 199 | '系统需要管理员才能执行帖子审核的操作,但是当前用户不是管理员', |
| 200 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 201 | return jsonify({'status': 'error', 'message': 'Unauthorized'}) |
| 202 | |
| 203 | res=f.review(data['postid'],data['status']) |
| 204 | if not res: |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 205 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 206 | 'error', |
| 207 | f'尝试审核帖子{data["postid"]}失败,帖子不存在', |
| 208 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 209 | return jsonify({'status': 'error', 'message': 'Post not found'}) |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 210 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 211 | 'behavior', |
| 212 | f'帖子审核成功,帖子ID: {data["postid"]} 状态更新为 {data["status"]}', |
| 213 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 214 | return jsonify({'status': 'success', 'message': 'Post reviewed successfully'}) |
| 215 | |
| 216 | |
| 217 | |
| 218 | @main.route('/nginxauth',methods=['POST','GET']) |
| 219 | def nginxauth(): |
| 220 | data=request.get_json() |
| 221 | engine=create_engine(Config.SQLURL) |
| 222 | SessionLocal = sessionmaker(bind=engine) |
| 223 | session = SessionLocal() |
| 224 | f=Fpost(session) |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 225 | checres,userid=f.checkid(data['userid'],'admin') |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 226 | if(not checres): |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 227 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 228 | 'error', |
| 229 | '系统需要管理员才能执行Nginx认证的操作,但是当前用户不是管理员', |
| 230 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 231 | return jsonify({'status': 'error', 'message': 'Unauthorized'}) |
| 232 | |
| 233 | res=f.nginxauth(data['postid'],data['status']) |
| 234 | if not res: |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 235 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 236 | 'error', |
| 237 | f'尝试更新Nginx认证状态失败,帖子{data["postid"]}不存在', |
| 238 | request.remote_addr) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 239 | return jsonify({'status': 'error', 'message': 'Post not found'}) |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 240 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 241 | 'behavior', |
| 242 | f'Nginx认证状态更新成功,帖子ID: {data["postid"]} 状态更新为 {data["status"]}', |
| 243 | request.remote_addr) |
| 244 | return jsonify({'status': 'success', 'message': 'Nginx auth updated successfully'}) |
| 245 | |
| 246 | @main.route('/getsyscost',methods=['POST','GET']) |
| 247 | def getsyscost(): |
| 248 | data=request.get_json() |
| 249 | engine=create_engine(Config.SQLURL) |
| 250 | SessionLocal = sessionmaker(bind=engine) |
| 251 | session = SessionLocal() |
| 252 | f=Fpost(session) |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 253 | checres,userid=f.checkid(data['userid'],'superadmin') |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 254 | if(not checres): |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 255 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 256 | 'error', |
| 257 | '系统需要管理员才能执行获取系统性能消耗的操作,但是当前用户不是管理员', |
| 258 | request.remote_addr) |
| 259 | return jsonify({'status': 'error', 'message': 'Unauthorized'}) |
TRM-coding | d1cbf67 | 2025-06-18 15:15:08 +0800 | [diff] [blame] | 260 | |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 261 | res=f.getsyscost() |
| 262 | if not res: |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 263 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 264 | 'error', |
| 265 | '尝试获取系统性能消耗数据失败,数据不存在', |
| 266 | request.remote_addr) |
| 267 | return jsonify({'status': 'error', 'message': 'No performance data found'}) |
| 268 | |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 269 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 270 | 'access', |
| 271 | '获取系统性能消耗数据成功', |
| 272 | request.remote_addr) |
| 273 | resdata = [] |
| 274 | for datai in res: |
| 275 | resdata.append({ |
| 276 | 'id': datai.id, |
| 277 | 'record_time': datai.record_time.isoformat(), |
| 278 | 'endpoint': datai.endpoint, |
| 279 | 'elapsed_time': datai.elapsed_time, |
| 280 | 'cpu_user': datai.cpu_user, |
| 281 | 'cpu_system': datai.cpu_system, |
| 282 | 'memory_rss': datai.memory_rss |
| 283 | }) |
| 284 | return jsonify(resdata) |
| 285 | @main.route('/getrecordlog',methods=['POST','GET']) |
| 286 | def getrecordlog(): |
| 287 | data=request.get_json() |
| 288 | engine=create_engine(Config.SQLURL) |
| 289 | SessionLocal = sessionmaker(bind=engine) |
| 290 | session = SessionLocal() |
| 291 | f=Fpost(session) |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 292 | checres,userid=f.checkid(data['userid'],'superadmin') |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 293 | if(not checres): |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 294 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 295 | 'error', |
| 296 | '系统需要管理员才能执行获取日志的操作,但是当前用户不是管理员', |
| 297 | request.remote_addr) |
| 298 | return jsonify({'status': 'error', 'message': 'Unauthorized'}) |
| 299 | |
| 300 | res=f.getrecordlog() |
| 301 | if not res: |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 302 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 303 | 'error', |
| 304 | '尝试获取日志失败,日志不存在', |
| 305 | request.remote_addr) |
| 306 | return jsonify({'status': 'error', 'message': 'No logs found'}) |
| 307 | |
TRM-coding | 2a8fd60 | 2025-06-19 19:33:16 +0800 | [diff] [blame^] | 308 | f.recordlog(userid, |
TRM-coding | c4b4f3d | 2025-06-18 19:02:46 +0800 | [diff] [blame] | 309 | 'access', |
| 310 | '获取日志成功', |
| 311 | request.remote_addr) |
| 312 | |
| 313 | resdata = [] |
| 314 | for datai in res: |
| 315 | resdata.append({ |
| 316 | 'id': datai.id, |
| 317 | 'user_id': datai.user_id, |
| 318 | 'type': datai.type, |
| 319 | 'content': datai.content, |
| 320 | 'ip': datai.ip, |
| 321 | 'created_at': datai.created_at.isoformat() |
| 322 | }) |
| 323 | |
| 324 | return jsonify(resdata) |
| 325 | |