__init__.py 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  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. import json
  15. import traceback
  16. from . import user
  17. from . import task
  18. from routers.api.riskManagement import risk_router
  19. from . import rescue_resources
  20. router = APIRouter()
  21. router.include_router(user.router, prefix="/inspection/user", tags=["巡查人员"])
  22. router.include_router(task.router, prefix="/inspection/task", tags=["巡查任务"])
  23. router.include_router(risk_router.router, prefix="/risk", tags=["风险防控"])
  24. router.include_router(rescue_resources.router, prefix="/rescue/resources", tags=["风险防控"])
  25. ####巡查人员--用户查询####
  26. @router.get('/system/user/list')
  27. async def userlist( userId: int = Query(None ,description='用户id'),
  28. nickName: str = Query(None, description='姓名'),
  29. page: int = Query(1, gt=0, description='页码'),
  30. pageSize: int = Query(10, gt=0, description='每页条目数量'),
  31. db: Session = Depends(get_db),
  32. user_id: int = Depends(valid_access_token)):
  33. try:
  34. def dept_id_get_dept_info( dept_id):
  35. query = db.query(SysDept)
  36. query = query.filter(SysDept.del_flag != '2')
  37. query = query.filter(SysDept.dept_id == dept_id)
  38. return query.first()
  39. def dept_id_get_ancestors_names(dept,ancestors_name=''):
  40. ancestors_name = '/' + dept.dept_name + ancestors_name
  41. if dept.parent_id==0:
  42. return ancestors_name
  43. else:
  44. return dept_id_get_ancestors_names(dept_id_get_dept_info(dept.parent_id),ancestors_name)
  45. # 构建查询
  46. query = db.query(SysUser)
  47. query = query.filter(SysUser.del_flag != '2')
  48. # 应用查询条件
  49. if nickName:
  50. query =query.filter(SysUser.nick_name.like(f'%{nickName}%'))
  51. if userId:
  52. query = query.filter(SysUser.user_id == userId)
  53. # 计算总条目数
  54. total_items = query.count()
  55. # 排序
  56. query = query.order_by(SysUser.create_time.desc())
  57. # 执行分页查询
  58. users = query.offset((page - 1) * pageSize).limit(pageSize).all()
  59. # 将查询结果转换为列表形式的字典
  60. user_list = []
  61. for user in users:
  62. # roleIds = user_id_get_user_roleIds(db, user.user_id)
  63. dept = dept_id_get_dept_info(user.dept_id)
  64. ancestors_names = dept_id_get_ancestors_names(dept)
  65. user_info = {
  66. "user_id": user.user_id,
  67. "dept_id": user.dept_id,
  68. "dept_name":dept.dept_name,
  69. "ancestors_names":ancestors_names,
  70. "user_name": user.user_name,
  71. "nick_name": user.nick_name,
  72. "phonenumber": user.phonenumber
  73. }
  74. user_list.append(user_info)
  75. # 返回结果
  76. return {
  77. "code": 200,
  78. "msg": "成功用户列表",
  79. "rows": user_list,
  80. "total": total_items,
  81. "page": page,
  82. "pageSize": pageSize,
  83. "totalPages": (total_items + pageSize - 1) // pageSize
  84. }
  85. except Exception as e:
  86. traceback.print_exc()
  87. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  88. @router.get("/allAreas")
  89. def read_all_areas(db: Session = Depends(get_db)):
  90. def parent_id_get_area_info(parent_id):
  91. query = db.query(GovdataArea)
  92. query = query.filter(GovdataArea.parent_id == parent_id)
  93. return query.all()
  94. def build_area_tree(areas, parent_area):
  95. # 收集祖先部门名称
  96. area_tree = []
  97. for area_info in areas:
  98. # current_area = db.query(GovdataArea).filter(GovdataArea.id == area_info.id).first()
  99. # ancestors_names = []
  100. # while current_area:
  101. # ancestors_names.append(current_area.area_name)
  102. # current_area = db.query(GovdataArea).filter(GovdataArea.id == current_area.parent_id).first()
  103. # ancestors_names.reverse()
  104. area = {
  105. "id": area_info.id,
  106. "code": area_info.area_code,
  107. "label": area_info.area_name,
  108. "parentId": area_info.parent_id,
  109. # "ancestors": '/'.join(ancestors_names)
  110. }
  111. # print(dept_info.dept_id)
  112. children = parent_id_get_area_info(area_info.id)
  113. if len(children) > 0:
  114. children_areas = build_area_tree(children, area)
  115. area["children"] = children_areas
  116. area_tree.append(area)
  117. return area_tree
  118. # data = build_area_tree(parent_id_get_area_info(0),None)
  119. filename = '/home/python3/xh_twapi01/routers/api/riskManagement/area_tree.json'
  120. # 打开文件并读取内容
  121. with open(filename, 'r', encoding='utf-8') as file:
  122. # 加载JSON内容到一个字典
  123. data = json.load(file)
  124. return {
  125. "code": 200,
  126. "msg": "成功",
  127. "data": data
  128. }