inspection.py 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. from fastapi import APIRouter, Request, Depends, Form, Body, File, UploadFile
  4. from database import get_db
  5. from utils.StripTagsHTMLParser import *
  6. from sqlalchemy.orm import Session
  7. from datetime import datetime, timedelta
  8. import jwt
  9. from passlib.context import CryptContext
  10. from models import *
  11. from sqlalchemy import text, exists, and_, or_, not_
  12. from sqlalchemy.sql import func
  13. from models import *
  14. from extensions import logger
  15. from utils import *
  16. import traceback
  17. router = APIRouter()
  18. # 2.2.4.智能巡检作业信息
  19. # 2.2.4.1.巡检计划信息
  20. @router.post('/plan/info', description='提交巡检计划信息')
  21. async def index(
  22. request: Request,
  23. db: Session = Depends(get_db),
  24. data: dict = Depends(remove_xss_json)
  25. ):
  26. try:
  27. id = get_req_param(data, 'id')
  28. info = db.query(DangerInspectionPlanInfo).filter(DangerInspectionPlanInfo.id == id).first()
  29. if info is None:
  30. new_entity = DangerInspectionPlanInfo(**data)
  31. db.add(new_entity)
  32. else:
  33. db.query(DangerInspectionPlanInfo).filter(DangerInspectionPlanInfo.id == id).update(data)
  34. db.commit()
  35. return {
  36. "code":1,
  37. "message":"成功",
  38. "data":{}
  39. }
  40. except Exception as e:
  41. traceback.print_exc()
  42. return {
  43. "code":0,
  44. "message":"更新异常,错误信息:" + str(e),
  45. "data":{}
  46. }
  47. # 2.2.4.2.巡检节点信息
  48. @router.post('/plan/point', description='提交巡检节点信息')
  49. async def index(
  50. request: Request,
  51. db: Session = Depends(get_db),
  52. data: dict = Depends(remove_xss_json)
  53. ):
  54. try:
  55. id = get_req_param(data, 'id')
  56. info = db.query(DangerInspectionPlanPoint).filter(DangerInspectionPlanPoint.id == id).first()
  57. if info is None:
  58. new_entity = DangerInspectionPlanPoint(**data)
  59. db.add(new_entity)
  60. else:
  61. db.query(DangerInspectionPlanPoint).filter(DangerInspectionPlanPoint.id == id).update(data)
  62. db.commit()
  63. return {
  64. "code":1,
  65. "message":"成功",
  66. "data":{}
  67. }
  68. except Exception as e:
  69. traceback.print_exc()
  70. return {
  71. "code":0,
  72. "message":"更新异常,错误信息:" + str(e),
  73. "data":{}
  74. }
  75. # 2.2.4.3.检查标准信息
  76. @router.post('/plan/rule', description='提交检查标准信息')
  77. async def index(
  78. request: Request,
  79. db: Session = Depends(get_db),
  80. data: dict = Depends(remove_xss_json)
  81. ):
  82. try:
  83. id = get_req_param(data, 'id')
  84. info = db.query(DangerInspectionPlanRule).filter(DangerInspectionPlanRule.id == id).first()
  85. if info is None:
  86. new_entity = DangerInspectionPlanRule(**data)
  87. db.add(new_entity)
  88. else:
  89. db.query(DangerInspectionPlanRule).filter(DangerInspectionPlanRule.id == id).update(data)
  90. db.commit()
  91. return {
  92. "code":1,
  93. "message":"成功",
  94. "data":{}
  95. }
  96. except Exception as e:
  97. traceback.print_exc()
  98. return {
  99. "code":0,
  100. "message":"更新异常,错误信息:" + str(e),
  101. "data":{}
  102. }
  103. # 2.2.4.4.巡检对象信息
  104. @router.post('/plan/obj', description='提交巡检对象信息')
  105. async def index(
  106. request: Request,
  107. db: Session = Depends(get_db),
  108. data: dict = Depends(remove_xss_json)
  109. ):
  110. try:
  111. id = get_req_param(data, 'id')
  112. info = db.query(DangerInspectionPlanObj).filter(DangerInspectionPlanObj.id == id).first()
  113. if info is None:
  114. new_entity = DangerInspectionPlanObj(**data)
  115. db.add(new_entity)
  116. else:
  117. db.query(DangerInspectionPlanObj).filter(DangerInspectionPlanObj.id == id).update(data)
  118. db.commit()
  119. return {
  120. "code":1,
  121. "message":"成功",
  122. "data":{}
  123. }
  124. except Exception as e:
  125. traceback.print_exc()
  126. return {
  127. "code":0,
  128. "message":"更新异常,错误信息:" + str(e),
  129. "data":{}
  130. }
  131. # 2.2.4.5.巡检任务信息
  132. @router.post('/task/info', description='提交巡检任务信息')
  133. async def index(
  134. request: Request,
  135. db: Session = Depends(get_db),
  136. data: dict = Depends(remove_xss_json)
  137. ):
  138. try:
  139. id = get_req_param(data, 'id')
  140. info = db.query(DangerInspectionTaskInfo).filter(DangerInspectionTaskInfo.id == id).first()
  141. if info is None:
  142. new_entity = DangerInspectionTaskInfo(**data)
  143. db.add(new_entity)
  144. else:
  145. db.query(DangerInspectionTaskInfo).filter(DangerInspectionTaskInfo.id == id).update(data)
  146. db.commit()
  147. return {
  148. "code":1,
  149. "message":"成功",
  150. "data":{}
  151. }
  152. except Exception as e:
  153. traceback.print_exc()
  154. return {
  155. "code":0,
  156. "message":"更新异常,错误信息:" + str(e),
  157. "data":{}
  158. }
  159. # 2.2.4.6.巡检记录信息
  160. @router.post('/task/record', description='提交巡检记录信息')
  161. async def index(
  162. request: Request,
  163. db: Session = Depends(get_db),
  164. data: dict = Depends(remove_xss_json)
  165. ):
  166. try:
  167. id = get_req_param(data, 'id')
  168. info = db.query(DangerInspectionTaskRecord).filter(DangerInspectionTaskRecord.id == id).first()
  169. if info is None:
  170. new_entity = DangerInspectionTaskRecord(**data)
  171. db.add(new_entity)
  172. else:
  173. db.query(DangerInspectionTaskRecord).filter(DangerInspectionTaskRecord.id == id).update(data)
  174. db.commit()
  175. return {
  176. "code":1,
  177. "message":"成功",
  178. "data":{}
  179. }
  180. except Exception as e:
  181. traceback.print_exc()
  182. return {
  183. "code":0,
  184. "message":"更新异常,错误信息:" + str(e),
  185. "data":{}
  186. }
  187. # 2.2.4.7.巡检统计结果信息
  188. @router.post('/task/statistics', description='提交巡检统计结果信息')
  189. async def index(
  190. request: Request,
  191. db: Session = Depends(get_db),
  192. data: dict = Depends(remove_xss_json)
  193. ):
  194. try:
  195. id = get_req_param(data, 'id')
  196. info = db.query(DangerInspectionTaskStatistics).filter(DangerInspectionTaskStatistics.id == id).first()
  197. if info is None:
  198. new_entity = DangerInspectionTaskStatistics(**data)
  199. db.add(new_entity)
  200. else:
  201. db.query(DangerInspectionTaskStatistics).filter(DangerInspectionTaskStatistics.id == id).update(data)
  202. db.commit()
  203. return {
  204. "code":1,
  205. "message":"成功",
  206. "data":{}
  207. }
  208. except Exception as e:
  209. traceback.print_exc()
  210. return {
  211. "code":0,
  212. "message":"更新异常,错误信息:" + str(e),
  213. "data":{}
  214. }