__init__.py 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. from fastapi import APIRouter, Request, Depends,Query, HTTPException, status
  4. from fastapi.responses import JSONResponse
  5. from sqlalchemy.orm import Session
  6. from sqlalchemy import and_, or_
  7. from pydantic import BaseModel
  8. from datetime import datetime
  9. from database import get_db
  10. from typing import List
  11. from models import *
  12. from utils import *
  13. import json
  14. router = APIRouter()
  15. class File(BaseModel):
  16. status :str
  17. name : str
  18. url : str
  19. class PlanCreateForm(BaseModel):
  20. planName : str
  21. planType : int
  22. # planTypeDesc : str
  23. publishDate: str
  24. organizingUnit : str
  25. document : str
  26. fileList : List[File]
  27. class PlanUpdateForm(BaseModel):
  28. planUid : str
  29. planName : str = None
  30. planType : int = None
  31. publishDate: str = None
  32. organizingUnit : str = None
  33. document : str = None
  34. fileList : List[File] = []
  35. class DrillCreateForm(BaseModel):
  36. planId : str
  37. drillName : str
  38. drillUnit : str
  39. year : int
  40. drillTime: str
  41. drillAddress : str
  42. lon : float
  43. lat : float
  44. drillProject : List[File]
  45. drillVideo : List[File]
  46. drillPicture : List[File]
  47. class DrillUpdateForm(BaseModel):
  48. drillId : str
  49. planId : str = None
  50. drillName : str = None
  51. drillUnit : str = None
  52. year : int = None
  53. drillTime: str = None
  54. drillAddress : str = None
  55. lon : float = None
  56. lat : float = None
  57. drillProject : List[File] = []
  58. drillVideo : List[File] = []
  59. drillPicture : List[File] = []
  60. class TrainingCreateForm(BaseModel):
  61. planId:str
  62. theme : str
  63. unitName : str
  64. trainingWay : str
  65. peopleNum: int
  66. startTime : str
  67. endTime : str
  68. Content :str
  69. address : str
  70. lon : float
  71. lat : float
  72. class TrainingUpdateForm(BaseModel):
  73. trainingId : str
  74. planId:str = None
  75. theme : str = None
  76. unitName : str = None
  77. trainingWay : str = None
  78. peopleNum: int = None
  79. startTime : str = None
  80. endTime : str = None
  81. Content :str = None
  82. address : str = None
  83. lon : float = None
  84. lat : float = None
  85. def get_file_query_fun(from_scenario,foreign_key,db: Session):
  86. file_query = db.query(EmergencyFile)
  87. file_query = file_query.filter(EmergencyFile.del_flag != '2')
  88. file_query = file_query.filter(EmergencyFile.from_scenario == from_scenario)
  89. file_query = file_query.filter(EmergencyFile.foreign_key == foreign_key)
  90. files = file_query.all()
  91. result = [{
  92. "uid": file.file_id,
  93. "status": file.status,
  94. "name": file.file_name_desc,
  95. "url": file.file_name #"/api/file/download/%s" %
  96. } for file in files]
  97. return result
  98. def delete_file_fun(from_scenario,foreign_key,db: Session):
  99. file_query = db.query(EmergencyFile)
  100. file_query = file_query.filter(EmergencyFile.del_flag != '2')
  101. file_query = file_query.filter(EmergencyFile.from_scenario == from_scenario)
  102. file_query = file_query.filter(EmergencyFile.foreign_key == foreign_key)
  103. files = file_query.all()
  104. for file in files:
  105. file.del_flag='2'
  106. # db.commit()
  107. def create_file_fun(file,from_scenario,foreign_key,db: Session):
  108. file_name = file.url
  109. file_name_desc = file.name
  110. status = file.status
  111. new_file = EmergencyFile(
  112. file_id=new_guid(),
  113. foreign_key=foreign_key,
  114. from_scenario=from_scenario,
  115. file_name=file_name,
  116. file_name_desc=file_name_desc,
  117. status=status
  118. )
  119. db.add(new_file)
  120. # db.commit()
  121. # db.refresh(new_file)
  122. @router.get('/plan/list')
  123. async def get_emergency_plan_list(
  124. planType: str = Query(None, description='预案类型'),
  125. # publishDate: datetime = Query(None, description='发布日期'),
  126. beginTime :str = Query(None, description='发布日期起始'),
  127. endTime :str = Query(None, description='发布日期结束'),
  128. # planName: str = Query(None, description='预案名称'),
  129. keywords : str = Query(None, description='预案名称/编制单位'),
  130. page: int = Query(1, gt=0, description='页码'),
  131. pageSize: int = Query(5, gt=0, description='每页条目数量'),
  132. db: Session = Depends(get_db)
  133. ):
  134. try:
  135. # 构建查询
  136. query = db.query(EmergencyPlan)
  137. query = query.filter(EmergencyPlan.del_flag != '2')
  138. # 应用查询条件
  139. if planType:
  140. query = query.filter(EmergencyPlan.plan_type == planType)
  141. # if publishDate:
  142. # query = query.filter(EmergencyPlan.publish_date == publishDate)
  143. if beginTime:
  144. query = query.filter(EmergencyPlan.publish_date >= beginTime)
  145. if endTime:
  146. query = query.filter(EmergencyPlan.publish_date <= endTime)
  147. if keywords:
  148. query = query.filter(
  149. or_(
  150. EmergencyPlan.plan_name.like(f'%{keywords}%'),
  151. EmergencyPlan.organizing_unit.like(f'%{keywords}%')
  152. )
  153. )
  154. # query = query.filter(EmergencyPlan.plan_name.like(f'%{planName}%'))
  155. # 计算总条目数
  156. total_items = query.count()
  157. # 排序
  158. query = query.order_by(EmergencyPlan.create_time.desc())
  159. # 执行分页查询
  160. emergency_plans = query.offset((page - 1) * pageSize).limit(pageSize).all()
  161. # 将查询结果转换为列表形式的字典
  162. emergency_plans_list = [
  163. {
  164. "planUid": plan.plan_id,
  165. "planId": plan.plan_number,
  166. "planName": plan.plan_name,
  167. "planType": plan.plan_type,
  168. "organizingUnit": plan.organizing_unit,
  169. "document": plan.document_number,
  170. "publishDate": plan.publish_date.strftime('%Y-%m-%d')
  171. }
  172. for plan in emergency_plans
  173. ]
  174. # 构建分页信息
  175. pagination_info = {
  176. }
  177. # 返回结果
  178. return {
  179. "code": 200,
  180. "msg": "成功获取预案列表",
  181. "data": emergency_plans_list,
  182. "total": total_items,
  183. "page": page,
  184. "pageSize": pageSize,
  185. "totalPages": (total_items + pageSize - 1) // pageSize
  186. }
  187. except Exception as e:
  188. # 处理异常
  189. raise HTTPException(status_code=500, detail=str(e))
  190. @router.get('/plan/{planId}')
  191. async def get_emergency_plan(
  192. planId: str ,
  193. db: Session = Depends(get_db)
  194. ):
  195. try:
  196. # 构建查询
  197. query = db.query(EmergencyPlan)
  198. query = query.filter(EmergencyPlan.del_flag != '2')
  199. # 应用查询条件
  200. if planId:
  201. query = query.filter(EmergencyPlan.plan_number == planId)
  202. # 执行查询
  203. emergency_plan = query.first()
  204. if not emergency_plan:
  205. detail = "预案不存在"
  206. raise HTTPException(status_code=404, detail="预案不存在")
  207. # 将查询结果转换为列表形式的字典
  208. emergency_plan_result = {
  209. "planUid": emergency_plan.plan_id,
  210. "planId": emergency_plan.plan_number,
  211. "planName": emergency_plan.plan_name,
  212. "planType": emergency_plan.plan_type,
  213. "organizingUnit": emergency_plan.organizing_unit,
  214. "document": emergency_plan.document_number,
  215. "publishDate": emergency_plan.publish_date.strftime('%Y-%m-%d'),
  216. "fileList": get_file_query_fun(from_scenario='emergencyPlans_plan',foreign_key=emergency_plan.plan_id,db=db)
  217. }
  218. # 返回结果
  219. return {
  220. "code": 200,
  221. "msg": "成功获取预案详情",
  222. "data": emergency_plan_result
  223. }
  224. except Exception as e:
  225. # 处理异常
  226. if str(e)=='':
  227. e = detail
  228. raise HTTPException(status_code=500, detail=str(e))
  229. @router.post('/plan/create')
  230. async def create_emergency_plan(
  231. form_data:PlanCreateForm,
  232. db: Session = Depends(get_db)
  233. ):
  234. try:
  235. # 提取请求数据
  236. plan_name = form_data.planName
  237. plan_type = form_data.planType
  238. # plan_type_desc = form_data.planTypeDesc
  239. publish_date = form_data.publishDate # 如果没有提供发布日期,则使用当前时间
  240. organizing_unit = form_data.organizingUnit # 使用用户位置作为编制单位
  241. document_number = form_data.document
  242. # 创建新的预案记录
  243. new_plan = EmergencyPlan(
  244. plan_id=new_guid(), # 假设使用 UUID 作为预案 UID
  245. plan_name=plan_name,
  246. plan_type=plan_type,
  247. # plan_type_desc=plan_type_desc,
  248. publish_date=publish_date,
  249. organizing_unit=organizing_unit,
  250. document_number=document_number
  251. )
  252. # 添加到数据库会话并提交
  253. db.add(new_plan)
  254. db.commit()
  255. db.refresh(new_plan) # 可选,如果需要刷新实例状态
  256. new_plan.plan_number= f'YJYA{str(new_plan.id).zfill(10)}'
  257. db.commit()
  258. for file in form_data.fileList:
  259. create_file_fun(file=file, from_scenario='emergencyPlans_plan', foreign_key=new_plan.plan_id, db=db)
  260. db.commit()
  261. # 返回创建成功的响应
  262. return {
  263. "code": 200,
  264. "msg": "预案创建成功",
  265. "data": None
  266. }
  267. except Exception as e:
  268. # 处理异常
  269. raise HTTPException(status_code=500, detail=str(e))
  270. @router.put('/plan/update')
  271. async def update_emergency_plan(
  272. form_data: PlanUpdateForm,
  273. db: Session = Depends(get_db)
  274. ):
  275. try:
  276. # 提取请求数据
  277. query = db.query(EmergencyPlan)
  278. query = query.filter(EmergencyPlan.plan_id == form_data.planUid)
  279. query = query.filter(EmergencyPlan.del_flag != '2')
  280. plan = query.first()
  281. if not plan:
  282. detail = "预案不存在"
  283. raise HTTPException(status_code=404, detail="预案不存在")
  284. if form_data.planName:
  285. plan.plan_name = form_data.planName
  286. if form_data.planType:
  287. plan.plan_type = form_data.planType
  288. if form_data.publishDate:
  289. plan.publish_date = form_data.publishDate
  290. if form_data.organizingUnit:
  291. plan.organizing_unit = form_data.organizingUnit
  292. if form_data.document:
  293. plan.document_number = form_data.document
  294. if len(form_data.fileList)>0:
  295. delete_file_fun(from_scenario='emergencyPlans_plan',foreign_key=plan.plan_id,db=db)
  296. for file in form_data.fileList:
  297. create_file_fun(file=file,from_scenario='emergencyPlans_plan',foreign_key=plan.plan_id,db=db)
  298. # 更新到数据库会话并提交
  299. db.commit()
  300. db.refresh(plan) # 可选,如果需要刷新实例状态
  301. # 返回创建成功的响应
  302. return {
  303. "code": 200,
  304. "msg": "预案更新成功",
  305. "data": None
  306. }
  307. except Exception as e:
  308. # 处理异常
  309. if str(e)=='':
  310. e = detail
  311. raise HTTPException(status_code=500, detail=str(e))
  312. @router.delete('/plan/delete')
  313. async def delete_emergency_plans(
  314. planUids: list,
  315. db: Session = Depends(get_db)
  316. ):
  317. try:
  318. # 提取请求数据
  319. query = db.query(EmergencyPlan)
  320. query = query.filter(EmergencyPlan.del_flag != '2')
  321. query = query.filter(EmergencyPlan.plan_id.in_(planUids))
  322. plans = query.all()
  323. if not plans:
  324. detail = "预案不存在"
  325. raise HTTPException(status_code=404, detail="预案不存在")
  326. for plan in plans:
  327. plan.del_flag = '2'
  328. # 更新到数据库会话并提交
  329. db.commit()
  330. # 返回创建成功的响应
  331. return {
  332. "code": 200,
  333. "msg": "预案删除成功",
  334. "data": None
  335. }
  336. except Exception as e:
  337. # 处理异常
  338. if str(e) == '':
  339. e = detail
  340. raise HTTPException(status_code=500, detail=str(e))
  341. @router.delete('/plan/delete/{planUid}')
  342. async def delete_emergency_plan(
  343. planUid: str,
  344. db: Session = Depends(get_db)
  345. ):
  346. try:
  347. # 提取请求数据
  348. query = db.query(EmergencyPlan)
  349. query = query.filter(EmergencyPlan.del_flag != '2')
  350. query = query.filter(EmergencyPlan.plan_id == planUid)
  351. plan = query.first()
  352. if not plan:
  353. detail = "预案不存在"
  354. raise HTTPException(status_code=404, detail="预案不存在")
  355. plan.del_flag = '2'
  356. # 更新到数据库会话并提交
  357. db.commit()
  358. db.refresh(plan) # 可选,如果需要刷新实例状态
  359. # 返回创建成功的响应
  360. return {
  361. "code": 200,
  362. "msg": "预案删除成功",
  363. "data": None
  364. }
  365. except Exception as e:
  366. # 处理异常
  367. if str(e) == '':
  368. e = detail
  369. raise HTTPException(status_code=500, detail=str(e))
  370. @router.get('/drill/list')
  371. async def get_emergency_drill_list(
  372. planNum: str = Query(None, description='预案编号'),
  373. page: int = Query(1, gt=0, description='页码'),
  374. pageSize: int = Query(5, gt=0, description='每页条目数量'),
  375. db: Session = Depends(get_db)
  376. ):
  377. try:
  378. # 构建查询
  379. query = db.query(EmergencyDrill)
  380. query = query.filter(EmergencyDrill.del_flag != '2')
  381. # 应用查询条件
  382. if planNum:
  383. query = query.filter(EmergencyDrill.plan_number == planNum)
  384. else:
  385. detail = "planNum不存在"
  386. raise HTTPException(status_code=404, detail="planNum不存在")
  387. # 计算总条目数
  388. total_items = query.count()
  389. query = query.order_by(EmergencyDrill.create_time.desc())
  390. # 执行分页查询
  391. emergency_drill = query.offset((page - 1) * pageSize).limit(pageSize).all() #
  392. print(emergency_drill)
  393. # 将查询结果转换为列表形式的字典
  394. emergency_drill_list = []
  395. for drill in emergency_drill:
  396. emergency_drill = {
  397. "drillId": drill.drill_id,
  398. "drillName": drill.drill_name,
  399. "drillUnit": drill.organizing_unit,
  400. "year": drill.planned_annual,
  401. "drillTime": drill.planned_time.strftime('%Y-%m-%d %H:%M:%S'),
  402. "drillAddress": drill.drill_location,
  403. "drillProject": get_file_query_fun(from_scenario='emergencyPlans_drill_project', foreign_key=drill.drill_id,db=db),
  404. "drillVideo": get_file_query_fun(from_scenario='emergencyPlans_drill_video', foreign_key=drill.drill_id,db=db),
  405. "drillPicture": get_file_query_fun(from_scenario='emergencyPlans_drill_pic', foreign_key=drill.drill_id,db=db)
  406. }
  407. emergency_drill_list.append(emergency_drill)
  408. # 返回结果
  409. return {
  410. "code": 200,
  411. "msg": "成功",
  412. "data": emergency_drill_list,
  413. "total": total_items,
  414. "page": page,
  415. "pageSize": pageSize,
  416. "totalPages": (total_items + pageSize - 1) // pageSize
  417. }
  418. except Exception as e:
  419. # 处理异常
  420. if str(e) == '':
  421. e = detail
  422. raise HTTPException(status_code=500, detail=str(e))
  423. @router.get('/drill/{drillId}')
  424. async def get_emergency_drill(
  425. drillId: str = Query(None, description='演练编号'),
  426. db: Session = Depends(get_db)
  427. ):
  428. try:
  429. # 构建查询
  430. query = db.query(EmergencyDrill)
  431. query = query.filter(EmergencyDrill.del_flag != '2')
  432. # 应用查询条件
  433. if drillId:
  434. query = query.filter(EmergencyDrill.drill_id == drillId)
  435. else:
  436. detail = "drillId不存在"
  437. raise HTTPException(status_code=404, detail="drillId不存在")
  438. # 执行查询
  439. drill = query.first()
  440. # 将查询结果转换为字典形式
  441. emergency_drill = {
  442. "drillId": drill.drill_id,
  443. "drillName": drill.drill_name,
  444. "drillUnit": drill.organizing_unit,
  445. "year": drill.planned_annual,
  446. "drillTime": drill.planned_time.strftime('%Y-%m-%d %H:%M:%S'),
  447. "drillAddress": drill.drill_location,
  448. "drillProject": get_file_query_fun(from_scenario='emergencyPlans_drill_project',foreign_key=drill.drill_id,db=db),
  449. "drillVideo": get_file_query_fun(from_scenario='emergencyPlans_drill_video', foreign_key=drill.drill_id,db=db),
  450. "drillPicture": get_file_query_fun(from_scenario='emergencyPlans_drill_pic', foreign_key=drill.drill_id,db=db)
  451. }
  452. # 返回结果
  453. return {
  454. "code": 200,
  455. "msg": "成功",
  456. "data": emergency_drill
  457. }
  458. except Exception as e:
  459. # 处理异常
  460. if str(e) == '':
  461. e = detail
  462. raise HTTPException(status_code=500, detail=str(e))
  463. @router.post('/drill/create')
  464. async def create_emergency_drill(
  465. form_data:DrillCreateForm,
  466. db: Session = Depends(get_db)
  467. ):
  468. try:
  469. # 提取请求数据
  470. plan_number = form_data.planId
  471. drill_name = form_data.drillName
  472. organizing_unit = form_data.drillUnit
  473. planned_annual = form_data.year
  474. planned_time = form_data.drillTime
  475. drill_location = form_data.drillAddress
  476. drill_lon = form_data.lon
  477. drill_lat = form_data.lat
  478. # 创建新的预案记录
  479. new_drill = EmergencyDrill(
  480. drill_id=new_guid(), # 假设使用 UUID 作为预案 UID
  481. plan_number = plan_number,
  482. drill_name=drill_name,
  483. organizing_unit = organizing_unit,
  484. planned_annual = planned_annual,
  485. planned_time = planned_time,
  486. drill_location = drill_location,
  487. drill_lon = drill_lon,
  488. drill_lat = drill_lat
  489. )
  490. # 添加到数据库会话并提交
  491. db.add(new_drill)
  492. db.commit()
  493. db.refresh(new_drill) # 可选,如果需要刷新实例状态
  494. for file in form_data.drillProject:
  495. create_file_fun(file=file, from_scenario='emergencyPlans_drill_project', foreign_key=new_drill.drill_id, db=db)
  496. for file in form_data.drillVideo:
  497. create_file_fun(file=file, from_scenario='emergencyPlans_drill_video', foreign_key=new_drill.drill_id, db=db)
  498. for file in form_data.drillPicture:
  499. create_file_fun(file=file, from_scenario='emergencyPlans_drill_pic', foreign_key=new_drill.drill_id, db=db)
  500. db.commit()
  501. # 返回创建成功的响应
  502. return {
  503. "code": 200,
  504. "msg": "演练创建成功",
  505. "data": None
  506. }
  507. except Exception as e:
  508. # 处理异常
  509. raise HTTPException(status_code=500, detail=str(e))
  510. @router.put('/drill/update')
  511. async def update_emergency_drill(
  512. form_data:DrillUpdateForm,
  513. db: Session = Depends(get_db)
  514. ):
  515. try:
  516. query = db.query(EmergencyDrill)
  517. query = query.filter(EmergencyDrill.drill_id == form_data.drillId)
  518. query = query.filter(EmergencyDrill.del_flag != '2')
  519. drill = query.first()
  520. # 判断预案编号是否存在,存在即更新
  521. if form_data.planId:
  522. drill.plan_number=form_data.planId
  523. # 判断演练名称是否存在,存在即更新
  524. if form_data.drillName:
  525. drill.drill_name=form_data.drillName
  526. # 判断演练单位是否存在,存在即更新
  527. if form_data.drillUnit:
  528. drill.organizing_unit=form_data.drillUnit
  529. # 判断演练年份是否存在,存在即更新
  530. if form_data.year:
  531. drill.planned_annual=form_data.year
  532. # 判断演练日期是否存在,存在即更新
  533. if form_data.drillTime:
  534. drill.planned_time=form_data.drillTime
  535. # 判断演练地址是否存在,存在即更新
  536. if form_data.drillAddress:
  537. drill.drill_location=form_data.drillAddress
  538. # 判断经度是否存在,存在即更新
  539. if form_data.lon:
  540. drill.drill_lon=form_data.lon
  541. # 判断纬度是否存在,存在即更新
  542. if form_data.lat:
  543. drill.drill_lat=form_data.lat
  544. # 判断演练方案是否存在,存在即更新
  545. if len(form_data.drillProject)>0:
  546. delete_file_fun(from_scenario='emergencyPlans_drill_project',foreign_key=drill.drill_id,db=db)
  547. for file in form_data.drillProject:
  548. create_file_fun(file=file,from_scenario='emergencyPlans_drill_project',foreign_key=drill.drill_id,db=db)
  549. # 判断演练视频是否存在,存在即更新
  550. if len(form_data.drillVideo) > 0:
  551. delete_file_fun(from_scenario='emergencyPlans_drill_video', foreign_key=drill.drill_id, db=db)
  552. for file in form_data.drillVideo:
  553. create_file_fun(file=file, from_scenario='emergencyPlans_drill_video', foreign_key=drill.drill_id,db=db)
  554. # 判断演练图片是否存在,存在即更新
  555. if len(form_data.drillPicture) > 0:
  556. delete_file_fun(from_scenario='emergencyPlans_drill_pic', foreign_key=drill.drill_id, db=db)
  557. for file in form_data.drillPicture:
  558. create_file_fun(file=file, from_scenario='emergencyPlans_drill_pic', foreign_key=drill.drill_id,db=db)
  559. # 提交所有更新
  560. db.commit()
  561. # 返回更新成功的响应
  562. return {
  563. "code": 200,
  564. "msg": "演练更新成功",
  565. "data": None
  566. }
  567. except Exception as e:
  568. # 处理异常
  569. raise HTTPException(status_code=500, detail=str(e))
  570. @router.delete('/drill/delete')
  571. async def delete_emergency_drill(
  572. drillUids: list,
  573. db: Session = Depends(get_db)
  574. ):
  575. try:
  576. # 提取请求数据
  577. query = db.query(EmergencyDrill)
  578. query = query.filter(EmergencyDrill.del_flag != '2')
  579. query = query.filter(EmergencyDrill.drill_id.in_(drillUids))
  580. drills = query.all()
  581. if not drills:
  582. detail = "演练不存在"
  583. raise HTTPException(status_code=404, detail="演练不存在")
  584. for drill in drills:
  585. drill.del_flag = '2'
  586. # 更新到数据库会话并提交
  587. db.commit()
  588. # 返回创建成功的响应
  589. return {
  590. "code": 200,
  591. "msg": "演练删除成功",
  592. "data": None
  593. }
  594. except Exception as e:
  595. # 处理异常
  596. if str(e) == '':
  597. e = detail
  598. raise HTTPException(status_code=500, detail=str(e))
  599. @router.delete('/drill/delete/{drillUid}')
  600. async def delete_emergency_drill(
  601. drillUid: str,
  602. db: Session = Depends(get_db)
  603. ):
  604. try:
  605. # 提取请求数据
  606. query = db.query(EmergencyDrill)
  607. query = query.filter(EmergencyDrill.del_flag != '2')
  608. query = query.filter(EmergencyDrill.drill_id == drillUid)
  609. drill = query.first()
  610. if not drill:
  611. detail = "演练不存在"
  612. raise HTTPException(status_code=404, detail="演练不存在")
  613. drill.del_flag = '2'
  614. # 更新到数据库会话并提交
  615. db.commit()
  616. db.refresh(drill) # 可选,如果需要刷新实例状态
  617. # 返回创建成功的响应
  618. return {
  619. "code": 200,
  620. "msg": "演练删除成功",
  621. "data": None
  622. }
  623. except Exception as e:
  624. # 处理异常
  625. if str(e) == '':
  626. e = detail
  627. raise HTTPException(status_code=500, detail=str(e))
  628. @router.get('/training/list')
  629. async def get_emergency_training_list(
  630. planNum: str = Query(None, description='预案编号'),
  631. page: int = Query(1, gt=0, description='页码'),
  632. pageSize: int = Query(5, gt=0, description='每页条目数量'),
  633. db: Session = Depends(get_db)
  634. ):
  635. try:
  636. # 构建查询
  637. query = db.query(EmergencyTrainingSession)
  638. query = query.filter(EmergencyTrainingSession.del_flag != '2')
  639. # 应用查询条件
  640. if planNum:
  641. query = query.filter(EmergencyTrainingSession.plan_number == planNum)
  642. else:
  643. detail = "planNum不存在"
  644. raise HTTPException(status_code=404, detail="planNum不存在")
  645. # 计算总条目数
  646. total_items = query.count()
  647. query = query.order_by(EmergencyTrainingSession.start_time.desc())
  648. # 执行分页查询
  649. emergency_training = query.offset((page - 1) * pageSize).limit(pageSize).all() #
  650. # print(emergency_drill)
  651. # 将查询结果转换为列表形式的字典
  652. emergency_training_list = [
  653. {
  654. "trainingId": training.training_id,
  655. "theme": training.training_theme,
  656. "unitName": training.training_unit,
  657. "peopleNum": training.participant_count,
  658. "trainingWay":training.training_method,
  659. "startTime":training.start_time.strftime('%Y-%m-%d %H:%M:%S'),
  660. "endTime": training.end_time.strftime('%Y-%m-%d %H:%M:%S'),
  661. "address": training.training_location,
  662. "Content":training.training_content
  663. }
  664. for training in emergency_training
  665. ]
  666. # 返回结果
  667. return {
  668. "code": 200,
  669. "msg": "成功",
  670. "data": emergency_training_list,
  671. "total": total_items,
  672. "page": page,
  673. "pageSize": pageSize,
  674. "totalPages": (total_items + pageSize - 1) // pageSize
  675. }
  676. except Exception as e:
  677. # 处理异常
  678. if str(e) == '':
  679. e = detail
  680. raise HTTPException(status_code=500, detail=str(e))
  681. @router.get('/training/{trainingId}')
  682. async def get_emergency_training(
  683. trainingId: str = Query(None, description='培训编号'),
  684. db: Session = Depends(get_db)
  685. ):
  686. try:
  687. # 构建查询
  688. query = db.query(EmergencyTrainingSession)
  689. query = query.filter(EmergencyTrainingSession.del_flag != '2')
  690. # 应用查询条件
  691. if trainingId:
  692. query = query.filter(EmergencyTrainingSession.training_id == trainingId)
  693. else:
  694. detail = "trainingId不存在"
  695. raise HTTPException(status_code=404, detail="trainingId不存在")
  696. # 执行查询
  697. training = query.first() #
  698. # 将查询结果转换为列表形式的字典
  699. emergency_training = {
  700. "trainingId": training.training_id,
  701. "theme": training.training_theme,
  702. "unitName": training.training_unit,
  703. "peopleNum": training.participant_count,
  704. "trainingWay":training.training_method,
  705. "startTime":training.start_time.strftime('%Y-%m-%d %H:%M:%S'),
  706. "endTime": training.end_time.strftime('%Y-%m-%d %H:%M:%S'),
  707. "address": training.training_location,
  708. "Content":training.training_content
  709. }
  710. # 返回结果
  711. return {
  712. "code": 200,
  713. "msg": "成功",
  714. "data": emergency_training
  715. }
  716. except Exception as e:
  717. # 处理异常
  718. if str(e) == '':
  719. e = detail
  720. raise HTTPException(status_code=500, detail=str(e))
  721. @router.post('/training/create')
  722. async def create_emergency_training(
  723. form_data:TrainingCreateForm,
  724. db: Session = Depends(get_db)
  725. ):
  726. try:
  727. # 创建新的预案记录
  728. new_training = EmergencyTrainingSession(
  729. training_id=new_guid(), # 假设使用 UUID 作为预案 UID
  730. training_theme=form_data.theme,
  731. training_unit=form_data.unitName,
  732. training_method=form_data.trainingWay,
  733. participant_count=form_data.peopleNum,
  734. start_time=form_data.startTime,
  735. end_time=form_data.endTime,
  736. training_content=form_data.Content,
  737. training_location=form_data.address,
  738. training_lon=form_data.lon,
  739. training_lat=form_data.lat,
  740. plan_number = form_data.planId
  741. )
  742. # 添加到数据库会话并提交
  743. db.add(new_training)
  744. db.commit()
  745. db.refresh(new_training) # 可选,如果需要刷新实例状态
  746. # 返回创建成功的响应
  747. return {
  748. "code": 200,
  749. "msg": "培训创建成功",
  750. "data": None
  751. }
  752. except Exception as e:
  753. # 处理异常
  754. raise HTTPException(status_code=500, detail=str(e))
  755. @router.put('/training/update')
  756. async def update_emergency_training(
  757. form_data:TrainingUpdateForm,
  758. db: Session = Depends(get_db)
  759. ):
  760. try:
  761. query = db.query(EmergencyTrainingSession)
  762. query = query.filter(EmergencyTrainingSession.training_id == form_data.trainingId)
  763. query = query.filter(EmergencyTrainingSession.del_flag != '2')
  764. training = query.first()
  765. # 判断预案编号是否存在,存在即更新
  766. if form_data.planId:
  767. training.plan_number = form_data.planId
  768. # 判断预案编号是否存在,存在即更新
  769. if form_data.theme:
  770. training.training_theme = form_data.theme
  771. # 判断预案编号是否存在,存在即更新
  772. if form_data.unitName:
  773. training.training_unit = form_data.unitName
  774. # 判断预案编号是否存在,存在即更新
  775. if form_data.trainingWay:
  776. training.training_method = form_data.trainingWay
  777. # 判断预案编号是否存在,存在即更新
  778. if form_data.peopleNum:
  779. training.participant_count = form_data.peopleNum
  780. # 判断预案编号是否存在,存在即更新
  781. if form_data.startTime:
  782. training.start_time = form_data.startTime
  783. # 判断预案编号是否存在,存在即更新
  784. if form_data.endTime:
  785. training.end_time = form_data.endTime
  786. # 判断预案编号是否存在,存在即更新
  787. if form_data.Content:
  788. training.training_content = form_data.Content
  789. # 判断预案编号是否存在,存在即更新
  790. if form_data.address:
  791. training.training_location = form_data.address
  792. # 判断预案编号是否存在,存在即更新
  793. if form_data.lon:
  794. training.training_lon = form_data.lon
  795. # 判断预案编号是否存在,存在即更新
  796. if form_data.lat:
  797. training.training_lat = form_data.lat
  798. # 提交
  799. db.commit()
  800. # 返回创建成功的响应
  801. return {
  802. "code": 200,
  803. "msg": "培训更新成功",
  804. "data": None
  805. }
  806. except Exception as e:
  807. # 处理异常
  808. raise HTTPException(status_code=500, detail=str(e))
  809. @router.delete('/training/delete')
  810. async def delete_emergency_training(
  811. trainingUids: list,
  812. db: Session = Depends(get_db)
  813. ):
  814. try:
  815. # 提取请求数据
  816. query = db.query(EmergencyTrainingSession)
  817. query = query.filter(EmergencyTrainingSession.del_flag != '2')
  818. query = query.filter(EmergencyTrainingSession.training_id.in_(trainingUids))
  819. trainings = query.all()
  820. if not trainings:
  821. detail = "培训不存在"
  822. raise HTTPException(status_code=404, detail="培训不存在")
  823. for training in trainings:
  824. training.del_flag = '2'
  825. # 更新到数据库会话并提交
  826. db.commit()
  827. # 返回创建成功的响应
  828. return {
  829. "code": 200,
  830. "msg": "培训删除成功",
  831. "data": None
  832. }
  833. except Exception as e:
  834. # 处理异常
  835. if str(e) == '':
  836. e = detail
  837. raise HTTPException(status_code=500, detail=str(e))
  838. @router.delete('/training/delete/{trainingUid}')
  839. async def delete_emergency_training(
  840. trainingUid: str,
  841. db: Session = Depends(get_db)
  842. ):
  843. try:
  844. # 提取请求数据
  845. query = db.query(EmergencyTrainingSession)
  846. query = query.filter(EmergencyTrainingSession.del_flag != '2')
  847. query = query.filter(EmergencyTrainingSession.training_id == trainingUid)
  848. training = query.first()
  849. if not training:
  850. detail = "培训不存在"
  851. raise HTTPException(status_code=404, detail="培训不存在")
  852. training.del_flag = '2'
  853. # 更新到数据库会话并提交
  854. db.commit()
  855. db.refresh(training) # 可选,如果需要刷新实例状态
  856. # 返回创建成功的响应
  857. return {
  858. "code": 200,
  859. "msg": "培训删除成功",
  860. "data": None
  861. }
  862. except Exception as e:
  863. # 处理异常
  864. if str(e) == '':
  865. e = detail
  866. raise HTTPException(status_code=500, detail=str(e))