user.py 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. from fastapi import APIRouter, Request, Depends,Query, HTTPException, status
  4. from common.security import valid_access_token
  5. from fastapi.responses import JSONResponse
  6. from sqlalchemy.orm import Session
  7. from sqlalchemy import and_, or_
  8. from pydantic import BaseModel
  9. from datetime import datetime
  10. from database import get_db
  11. from typing import List
  12. from models import *
  13. from utils import *
  14. from utils.ry_system_util import *
  15. from utils.riskManagement_uitl import *
  16. import json
  17. import traceback
  18. import xlrd
  19. import os
  20. from common.enc import mpfun
  21. router = APIRouter()
  22. # 目录在文档上传接口写死
  23. UPLOAD_mergefile_PATH = '/data/upload/mergefile'
  24. @router.get('/list')
  25. async def get_inspection_user_list(
  26. nickName: str = Query(None, description='姓名'),
  27. deptId :str = Query(None, description='部门id'),
  28. page: int = Query(1, gt=0, description='页码'),
  29. pageSize: int = Query(5, gt=0, description='每页条目数量'),
  30. db: Session = Depends(get_db),
  31. user_id = Depends(valid_access_token)
  32. ):
  33. try:
  34. # 应用查询条件
  35. query = db.query(SysUser)
  36. query = query.filter(SysUser.del_flag != '2')
  37. if nickName:
  38. query = query.filter(SysUser.nick_name.like(f'%{nickName}%'))
  39. if deptId:
  40. user_ids = [i.user_id for i in dept_id_get_user_info(db,deptId)]
  41. query = query.filter(SysUser.user_id.in_(user_ids))
  42. user_ids = [i.user_id for i in query.all()]
  43. # 构建查询
  44. query = db.query(RiskManagementInspectionUser)
  45. query = query.filter(RiskManagementInspectionUser.del_flag != '2')
  46. query = query.filter(RiskManagementInspectionUser.user_id.in_(user_ids))
  47. # 计算总条目数
  48. total_items = query.count()
  49. # 排序
  50. query = query.order_by(RiskManagementInspectionUser.create_time.desc())
  51. # 执行分页查询
  52. InspectionUsers = query.offset((page - 1) * pageSize).limit(pageSize).all()
  53. # 将查询结果转换为列表形式的字典
  54. InspectionUsers_list = []
  55. for user in InspectionUsers:
  56. user_info = user_id_get_user_info(db,user.user_id)
  57. dept = dept_id_get_dept_info(db,user_info.dept_id)
  58. # print(dept)
  59. ancestors_names = dept_id_get_ancestors_names(db,dept)
  60. area_code = user.area_code
  61. area = area_code_get_area_info(db,area_code)
  62. area = area_code_get_ancestors_names(db,area)
  63. user_info = {
  64. "id": user.id,
  65. "user_id": user.user_id,
  66. "dept_id": user_info.dept_id,
  67. "dept_name": dept.dept_name,
  68. "ancestors_names": ancestors_names,
  69. "user_name": user_info.user_name,
  70. "create_time": user.create_time.strftime('%Y-%m-%d'),
  71. "phonenumber": mpfun.dec_data(user_info.phonenumber),
  72. "nick_name": user_info.nick_name,
  73. "area_code": user.area_code,
  74. "area": area,
  75. "yzy_account":user_info.yzy_account
  76. }
  77. InspectionUsers_list.append(user_info)
  78. # 返回结果
  79. return {
  80. "code": 200,
  81. "msg": "成功",
  82. "data": InspectionUsers_list,
  83. "total": total_items,
  84. "page": page,
  85. "pageSize": pageSize,
  86. "totalPages": (total_items + pageSize - 1) // pageSize
  87. }
  88. except Exception as e:
  89. # 处理异常
  90. traceback.print_exc()
  91. raise HTTPException(status_code=500, detail=str(e))
  92. @router.get('/{id}')
  93. async def get_inspection_user(
  94. id: str ,
  95. db: Session = Depends(get_db),
  96. user_id = Depends(valid_access_token)
  97. ):
  98. try:
  99. # 构建查询
  100. query = db.query(RiskManagementInspectionUser)
  101. query = query.filter(RiskManagementInspectionUser.del_flag != '2')
  102. # 应用查询条件
  103. if id:
  104. query = query.filter(RiskManagementInspectionUser.id == id)
  105. # 执行查询
  106. user = query.first()
  107. if not user:
  108. detail = "用户不存在"
  109. raise HTTPException(status_code=404, detail="用户不存在")
  110. # 将查询结果转换为列表形式的字典
  111. user_info = user_id_get_user_info(db, user.user_id)
  112. dept = dept_id_get_dept_info(db, user_info.dept_id)
  113. # print(dept)
  114. ancestors_names = dept_id_get_ancestors_names(db, dept)
  115. area_code = user.area_code
  116. area = area_code_get_area_info(db, area_code)
  117. area = area_code_get_ancestors_names(db, area)
  118. inspection_user_result = {
  119. "id": user.id,
  120. "user_id": user.user_id,
  121. "dept_id": user_info.dept_id,
  122. "dept_name": dept.dept_name,
  123. "ancestors_names": ancestors_names,
  124. "user_name": user_info.user_name,
  125. "create_time": user.create_time.strftime('%Y-%m-%d'),
  126. "phonenumber": user_info.phonenumber,
  127. "nick_name": user_info.nick_name,
  128. "area_code": user.area_code,
  129. "area": area,
  130. "yzy_account": user_info.yzy_account
  131. }
  132. # inspection_user_result = {
  133. # "id": user.id,
  134. # "user_id": user.user_id,
  135. # "dept_id": user.dept_id,
  136. # "dept_name": user.dept_name,
  137. # "ancestors_names": user.ancestors_names,
  138. # "user_name": user.user_name,
  139. # "create_time": user.create_time.strftime('%Y-%m-%d'),
  140. # "phonenumber": user.phonenumber,
  141. # "nick_name": user.nick_name,
  142. # "area_code": user.area_code,
  143. # "area": user.area,
  144. # "yzy_account":user.yzy_account
  145. # }
  146. # 返回结果
  147. return {
  148. "code": 200,
  149. "msg": "成功",
  150. "data": inspection_user_result
  151. }
  152. except Exception as e:
  153. # 处理异常
  154. traceback.print_exc()
  155. if str(e)=='':
  156. e = detail
  157. raise HTTPException(status_code=500, detail=str(e))
  158. @router.post('/create')
  159. async def create_inspection_user(
  160. db: Session = Depends(get_db),
  161. body = Depends(remove_xss_json),
  162. user_id = Depends(valid_access_token)
  163. ):
  164. try:
  165. # user_id_1 = body['user_id']
  166. # area_code = body['area_code']
  167. # dept_id = None
  168. # ancestors_names=None
  169. # if 'dept_id' in body:
  170. # dept_id=body['dept_id']
  171. # dept = dept_id_get_dept_info(db,dept_id)
  172. # # print(dept)
  173. # ancestors_names = dept_id_get_ancestors_names(db,dept)
  174. # dept_name = None
  175. # if 'dept_name' in body:
  176. # dept_name=body['dept_name']
  177. # phonenumber = None
  178. # if 'phonenumber' in body:
  179. # phonenumber=body['phonenumber']
  180. # 创建新的预案记录
  181. new_user = RiskManagementInspectionUser(
  182. user_id=body['user_id'],
  183. # dept_id = dept_id,#body['dept_id'],
  184. # dept_name = dept_name,#body['dept_name'],
  185. # ancestors_names = ancestors_names,#body['ancestors_names'],
  186. # user_name = '',#body['user_name'],
  187. # nick_name = '',#body['nick_name'],
  188. # phonenumber = phonenumber,#body['phonenumber'],
  189. area_code = body['area_code'],
  190. # area = '',#body['area'],
  191. # yzy_account = '',#body['yzy_account'],
  192. create_by = user_id
  193. )
  194. # 添加到数据库会话并提交
  195. db.add(new_user)
  196. db.commit()
  197. db.refresh(new_user) # 可选,如果需要刷新实例状态
  198. # 返回创建成功的响应
  199. return {
  200. "code": 200,
  201. "msg": "成功",
  202. "data": None
  203. }
  204. except Exception as e:
  205. # 处理异常
  206. traceback.print_exc()
  207. raise HTTPException(status_code=500, detail=str(e))
  208. @router.put('/update')
  209. async def update_inspection_user(
  210. db: Session = Depends(get_db),
  211. body = Depends(remove_xss_json),
  212. user_id = Depends(valid_access_token)
  213. ):
  214. try:
  215. # 提取请求数据
  216. query = db.query(RiskManagementInspectionUser)
  217. query = query.filter(RiskManagementInspectionUser.id == body['id'])
  218. query = query.filter(RiskManagementInspectionUser.del_flag != '2')
  219. user = query.first()
  220. if not user:
  221. detail = "用户不存在"
  222. raise HTTPException(status_code=404, detail="用户不存在")
  223. if 'user_id' in body:
  224. user.user_id = body['user_id']
  225. # if 'dept_id' in body:
  226. # user.dept_id = body['dept_id']
  227. # if 'dept_name' in body:
  228. # user.dept_name = body['dept_name']
  229. # if 'ancestors_names' in body:
  230. # user.ancestors_names = body['ancestors_names']
  231. # if 'user_name' in body:
  232. # user.user_name = body['user_name']
  233. # if 'nick_name' in body:
  234. # user.nick_name = body['nick_name']
  235. # if 'phonenumber' in body:
  236. # user.phonenumber = body['phonenumber']
  237. if 'area_code' in body:
  238. user.area_code = body['area_code']
  239. # if 'area' in body:
  240. # user.area = body['area']
  241. if user_id:
  242. user.update_by = user_id
  243. # 更新到数据库会话并提交
  244. db.commit()
  245. db.refresh(user) # 可选,如果需要刷新实例状态
  246. # 返回创建成功的响应
  247. return {
  248. "code": 200,
  249. "msg": "成功",
  250. "data": None
  251. }
  252. except Exception as e:
  253. # 处理异常
  254. traceback.print_exc()
  255. if str(e)=='':
  256. e = detail
  257. raise HTTPException(status_code=500, detail=str(e))
  258. @router.delete('/delete')
  259. async def delete_inspection_users(
  260. userIds: list,
  261. db: Session = Depends(get_db),
  262. body = Depends(remove_xss_json),
  263. user_id = Depends(valid_access_token)
  264. ):
  265. try:
  266. # 提取请求数据
  267. query = db.query(RiskManagementInspectionUser)
  268. query = query.filter(RiskManagementInspectionUser.del_flag != '2')
  269. query = query.filter(RiskManagementInspectionUser.id.in_(userIds))
  270. users = query.all()
  271. print(userIds)
  272. if not users:
  273. detail = "用户不存在"
  274. raise HTTPException(status_code=404, detail="用户不存在")
  275. for user in users:
  276. user.del_flag = '2'
  277. user.update_by=user_id
  278. # 更新到数据库会话并提交
  279. db.commit()
  280. # 返回创建成功的响应
  281. return {
  282. "code": 200,
  283. "msg": "删除成功",
  284. "data": None
  285. }
  286. except Exception as e:
  287. # 处理异常
  288. traceback.print_exc()
  289. if str(e) == '':
  290. e = detail
  291. raise HTTPException(status_code=500, detail=str(e))
  292. @router.delete('/delete/{userId}')
  293. async def delete_inspection_user(
  294. userId: str,
  295. db: Session = Depends(get_db),
  296. body = Depends(remove_xss_json),
  297. user_id = Depends(valid_access_token)
  298. ):
  299. try:
  300. # 提取请求数据
  301. query = db.query(RiskManagementInspectionUser)
  302. query = query.filter(RiskManagementInspectionUser.del_flag != '2')
  303. query = query.filter(RiskManagementInspectionUser.id==userId)
  304. user = query.first()
  305. if not user:
  306. detail = "用户不存在"
  307. raise HTTPException(status_code=404, detail="用户不存在")
  308. user.del_flag = '2'
  309. user.update_by = user_id
  310. # 更新到数据库会话并提交
  311. db.commit()
  312. db.refresh(user) # 可选,如果需要刷新实例状态
  313. # 返回创建成功的响应
  314. return {
  315. "code": 200,
  316. "msg": "删除成功",
  317. "data": None
  318. }
  319. except Exception as e:
  320. # 处理异常
  321. traceback.print_exc()
  322. if str(e) == '':
  323. e = detail
  324. raise HTTPException(status_code=500, detail=str(e))
  325. # 导入
  326. @router.post('/import')
  327. async def import_doc(
  328. request: Request,
  329. db: Session = Depends(get_db),
  330. body = Depends(remove_xss_json),
  331. user_id = Depends(valid_access_token)
  332. ):
  333. try:
  334. filename = body['filename']
  335. if len(filename) == 0:
  336. raise Exception()
  337. file = filename[0]
  338. url = file['url']
  339. file_path = f"{UPLOAD_mergefile_PATH}/uploads/{url}"
  340. file_path = os.path.abspath(file_path)
  341. print(file_path)
  342. book = xlrd.open_workbook(file_path)
  343. sheet = book.sheet_by_index(0)
  344. data = []
  345. return {
  346. 'code': 200,
  347. 'msg': '导入成功'
  348. }
  349. except Exception:
  350. traceback.print_exc()
  351. return {
  352. 'code': 500,
  353. 'msg': '导入发生异常'
  354. }