videoinfo.py 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. from fastapi import APIRouter, Request, Depends,Query,HTTPException,status
  4. from fastapi.responses import StreamingResponse
  5. from database import get_db
  6. from sqlalchemy.orm import Session
  7. from sqlalchemy import case,or_
  8. from sqlalchemy import inspect
  9. from sqlalchemy import text
  10. from utils import *
  11. from utils.ry_system_util import *
  12. from utils.video_util import *
  13. from common.security import valid_access_token
  14. from common.db import db_czrz
  15. from common.auth_user import *
  16. from fastapi.responses import JSONResponse
  17. import traceback
  18. from datetime import datetime
  19. router = APIRouter()
  20. @router.get('/video_from')
  21. async def get_dict_data_by_type(
  22. db: Session = Depends(get_db),
  23. body = Depends(remove_xss_json),
  24. user_id = Depends(valid_access_token)
  25. ):
  26. # 视频来源
  27. try:
  28. # 根据 dict_type 查询字典数据
  29. query = db.query(TPVideoRegion)
  30. # 添加查询条件
  31. # if dictType:
  32. query = query.filter(TPVideoRegion.parentIndexCode=='root00000000')
  33. query = query.filter(TPVideoRegion.status == '0')
  34. query = query.order_by(TPVideoRegion.sort)
  35. dict_data = query.all()
  36. # 转换为字典
  37. dict_data_list = [
  38. {
  39. "dictCode": d.indexCode,
  40. "dictSort": d.sort,
  41. "dictLabel": d.name,
  42. "dictValue": d.indexCode,
  43. "dictType": 'video',
  44. "cssClass": '',
  45. "listClass": 'default',
  46. "isDefault": 'N',
  47. "remark": '',
  48. "createTime": d.createTime.strftime('%Y-%m-%d %H:%M:%S') if d.createTime else ''
  49. }
  50. for d in dict_data
  51. ]
  52. # 构建返回结果
  53. result = {
  54. "rows": dict_data_list,
  55. "code": 200,
  56. "msg": "查询成功"
  57. }
  58. return result
  59. except Exception as e:
  60. # 处理异常
  61. raise HTTPException(status_code=status.HTTP_500_INTERNAL_SERVER_ERROR, detail=str(e))
  62. @router.get('/get_video_list_new')
  63. async def get_video_url_by_id(
  64. area_code: str = Query(None, description='区划编码'),
  65. video_from: str = Query(None, description='视频来源'),
  66. video_tag: str = Query(None, description='视频标签'),
  67. video_name: str = Query(None, description='视频名称'),
  68. longitude: float = Query(None, description='经度'),
  69. latitude: float = Query(None, description='纬度'),
  70. db: Session = Depends(get_db),
  71. body=Depends(remove_xss_json),
  72. user_id=Depends(valid_access_token),
  73. page: int = Query(1, gt=0, description='页码'),
  74. pageSize: int = Query(10, gt=0, description='每页条目数量')
  75. ):
  76. # 大屏左下角视频及更多视频
  77. try:
  78. query = db.query(TPVideoInfo)
  79. if area_code:
  80. query = query.filter(TPVideoInfo.gbIndexCode.like(f'%{area_code}%'))
  81. if video_from:
  82. query = query.filter(TPVideoInfo.regionPath.like(f'%{video_from}%'))
  83. if video_name:
  84. query = query.filter(TPVideoInfo.name.like(f'%{video_name}%'))
  85. if video_tag:
  86. tag_info = get_dict_data_info(db, 'video_type', video_tag)
  87. if tag_info:
  88. if tag_info.dict_label != '全量视频':
  89. videoli = [info.video_code for info in tag_get_video_tag_list(db, video_tag)]
  90. query = query.filter(TPVideoInfo.gbIndexCode.in_(videoli))
  91. videoIds = user_id_get_user_videoIds(db, user_id)
  92. video_list = [i.video_code_int for i in videoIds]
  93. if video_list:
  94. video_priority_case = case(
  95. [
  96. (TPVideoInfo.gbIndexCode == i, 0)
  97. for i in video_list
  98. ],
  99. else_=1
  100. ).label('user_priority')
  101. query = query.add_columns(video_priority_case).order_by('user_priority')
  102. if longitude is not None and latitude is not None:
  103. point = func.ST_GeomFromText(f'POINT({latitude} {longitude})', 4326)
  104. query = query.add_columns(
  105. func.ST_Distance_Sphere(TPVideoInfo.location, point).label('distance')
  106. ).order_by('distance')
  107. total_items = query.count()
  108. videos = query.offset(pageSize * (page - 1)).limit(pageSize).all()
  109. data = []
  110. for row in videos:
  111. row = row[0]
  112. # print(type(row),row[0])
  113. tag_list =get_video_tag_list(db,row.gbIndexCode)
  114. tag = []
  115. tag_lable = []
  116. for info in tag_list:
  117. tag_info = get_dict_data_info(db, 'video_type', info.dict_value)
  118. if tag_info:
  119. if tag_info.dict_label not in tag_lable and tag_info.dict_label!='全量视频':
  120. tag.append({"id": info.id,
  121. "video_code": row.gbIndexCode,
  122. "dict_type": info.dict_type,
  123. "dict_value": info.dict_value,
  124. "dict_label": tag_info.dict_label,
  125. "dict_code": tag_info.dict_code})
  126. tag_lable.append(tag_info.dict_label)
  127. data.append({
  128. "name":row.name,
  129. "isUserVideos":row.gbIndexCode in video_list,
  130. "video_code": row.gbIndexCode,
  131. "isTag" : len(tag_list)>0,
  132. "tag" : tag,
  133. "tagLabels" : "、".join(tag_lable),
  134. "status":row.status,
  135. "statusName":row.statusName,
  136. "regionPath":row.regionPath,
  137. "installPlace":row.installPlace,
  138. "cameraTypeName":row.cameraTypeName,
  139. "cameraType":row.cameraType
  140. })
  141. return {
  142. "code": 200,
  143. "msg": "操作成功",
  144. "data": data,
  145. "total": total_items,
  146. "page": page,
  147. "pageSize": pageSize,
  148. "totalPages": (total_items + pageSize - 1) // pageSize
  149. }
  150. except Exception as e:
  151. # 处理异常
  152. traceback.print_exc()
  153. raise HTTPException(status_code=status.HTTP_500_INTERNAL_SERVER_ERROR, detail=str(e))
  154. @router.get('/get_video_list_by_user')
  155. async def get_video_url_by_id(
  156. longitude:float = Query(None, description='经度'),
  157. latitude:float = Query(None, description='纬度'),
  158. db: Session = Depends(get_db),
  159. body=Depends(remove_xss_json),
  160. user_id=Depends(valid_access_token),
  161. page: int = Query(1, gt=0, description='页码'),
  162. pageSize: int = Query(10, gt=0, description='每页条目数量')
  163. ):
  164. # 用户视频排序
  165. if longitude is not None and latitude is not None:
  166. location = f"""ST_Distance_Sphere(
  167. ST_GeomFromText(CONCAT('POINT(', longitude, ' ', latitude, ')')),
  168. ST_PointFromText('POINT({longitude} {latitude})'))"""
  169. orddis = 'distance'
  170. else:
  171. location = 0
  172. orddis = ''
  173. videoIds = user_id_get_user_videoIds(db, user_id)
  174. video_list = [i.video_code_int for i in videoIds]
  175. if len(video_list)==0:
  176. video = ''
  177. else:
  178. video = ""
  179. for i in video_list:
  180. video += f"WHEN '{i}' THEN 0 \n"
  181. video = f"""CASE video_code_int
  182. {video}
  183. ELSE 1
  184. END """
  185. if orddis != '' and video !='':
  186. video += ','
  187. sql = f"""SELECT T1.indexcode,T2.`name`,T1.longitude,T1.latitude,
  188. {location} AS distance,T2.area,T2.ip,T2.`status`,T2.status_lifetime,T2.record_status,T2.inspection_datetime,T2.video_code_int,T2.video_code
  189. FROM tp_video_base T1 RIGHT JOIN tp_video_log T2 on T1.indexcode=T2.video_code_int -- where T1.longitude is not NULL
  190. ORDER BY {video} {orddis} """
  191. totalsql = f'select count(*) from ({sql})t'
  192. print(video_list)
  193. total_items = db.execute(totalsql).first()[0]
  194. lim = f"limit {pageSize*(page-1)}, {pageSize};"
  195. videos = db.execute(sql+lim).all()
  196. video_list1 = []
  197. for video in videos:
  198. videoInfo = {
  199. "name": video.name,
  200. "invideoIds": video.video_code_int in video_list,
  201. "area": video.area,
  202. "ip": video.ip,
  203. "status": video.status,
  204. "status_lifetime": video.status_lifetime,
  205. "record_status": video.record_status,
  206. "inspection_datetime": video.inspection_datetime,
  207. "video_code_int": video.video_code_int,
  208. "video_code": video.video_code,
  209. "longitude":video.longitude,
  210. "latitude":video.latitude
  211. }
  212. video_list1.append(videoInfo)
  213. return {
  214. "code": 200,
  215. "msg": "操作成功",
  216. "rows": video_list1,
  217. "total": total_items,
  218. "page": page,
  219. "pageSize": pageSize,
  220. "totalPages": (total_items + pageSize - 1) // pageSize
  221. }
  222. @router.get('/get_waterlogged_all_video_info')
  223. async def get_waterlogged_all_video_info(
  224. radius:int = Query(None),
  225. db: Session = Depends(get_db),
  226. body=Depends(remove_xss_json),
  227. page: int = Query(1, gt=0, description='页码'),
  228. pageSize: int = Query(10, gt=0, description='每页条目数量'),
  229. user_id=Depends(valid_access_token)):
  230. # 雨窝点视频
  231. try:
  232. if radius is None:
  233. radius=500
  234. print(1,datetime.now)
  235. sql = f"""SELECT * from mid_waterlogged_roads """
  236. waterlogged_data = db.execute(sql).all()
  237. resutl = []
  238. print(2,datetime.now)
  239. tj = []
  240. for location_1 in waterlogged_data:
  241. location = f"POINT({location_1.lng} {location_1.lat})"
  242. tj.append(f"ST_Distance_Sphere(ST_GeomFromText(CONCAT('POINT(', longitude, ' ', latitude, ')')),ST_GeomFromText(CONCAT('{location}'))) <= '{radius}'")
  243. tj = ' or '.join(tj)
  244. sql = text(f"""SELECT indexcode,`name`,longitude,latitude FROM (
  245. SELECT indexcode,`name`,longitude,latitude
  246. FROM tp_video_base where longitude is not null and latitude is not null and ({tj}) and `status`='ON'
  247. ) T limit {pageSize*(page-1)}, {pageSize}""")
  248. resutl=db.execute(sql).all()
  249. print(3, datetime.now)
  250. total_items = len(resutl)
  251. print(4,datetime.now)
  252. return {
  253. "code": 200,
  254. "msg": "成功",
  255. "data": {"list":[{"indexcode":info.indexcode,"name":info.name,"longitude":info.longitude,"latitude":info.latitude} for info in resutl[(page - 1) * pageSize:(page - 1) * pageSize+pageSize]]},
  256. "page": page,
  257. "pageSize": pageSize,
  258. "totalPages": (total_items + pageSize - 1) // pageSize
  259. }
  260. except Exception as e:
  261. traceback.print_exc()
  262. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  263. @router.get('/get_video_list')
  264. async def get_video_forest_fire_list(
  265. video_type:str = Query(None),
  266. area:str = Query(None),
  267. name:str = Query(None),
  268. db: Session = Depends(get_db),
  269. page: int = Query(1, gt=0, description='页码'),
  270. pageSize: int = Query(0, gt=0, description='每页条目数量'),
  271. body=Depends(remove_xss_json),
  272. user_id=Depends(valid_access_token)):
  273. try:
  274. sql = '''SELECT T1.`name`,IF(T1.`status`='在线',1,0) as `status`,T1.`video_code_int`as `video_code`,IFNULL(IFNULL(T3.longitude,T2.longitude),0) as longitude,IFNULL(IFNULL(T3.latitude,T2.latitude),0) as latitude,CASE
  275. WHEN IFNULL(T3.area,T1.area) like '%高州%' THEN
  276. '440981'
  277. WHEN IFNULL(T3.area,T1.area) like '%信宜%' THEN
  278. '440983'
  279. WHEN IFNULL(T3.area,T1.area) like '%化州%' THEN
  280. '440982'
  281. WHEN IFNULL(T3.area,T1.area) like '%茂南%' THEN
  282. '440902'
  283. WHEN IFNULL(T3.area,T1.area) like '%电白%' THEN
  284. '440904'
  285. ELSE
  286. '440900'
  287. END
  288. as area FROM tp_video_log T1 LEFT JOIN (SELECT indexcode,longitude,latitude FROM `tp_video_base`where latitude>0) T2 on T1.video_code_int=T2.indexcode LEFT JOIN tp_video_log_transportation_area_info T3 on T1.video_code_int=T3.video_code where 1=1 and T2.longitude>0 '''
  289. if video_type:
  290. sql += f''' and T1.video_code_int in (select video_code from Tp_Video_Tag where del_flag ='0' and dict_value='{video_type}')'''
  291. if name:
  292. sql += f''' and T1.name like '%{name}%' '''
  293. # 计算总条目数
  294. totalsql = f'select count(*) as ct from ({sql})t where longitude > 0'
  295. total_items = db.execute(totalsql).first().ct
  296. # 排序
  297. if pageSize!=0:
  298. sql = f'''select * from ({sql} limit {pageSize*(page-1)}, {pageSize})t where longitude > 0 '''
  299. video_list = db.execute(sql).all()
  300. totalPages= (total_items + pageSize - 1) // pageSize
  301. else:
  302. pageSize = total_items
  303. totalPages = 1
  304. video_list = db.execute(f"""select * from ({sql})t where longitude > 0 """).all()
  305. result = []
  306. for video_info in video_list:
  307. longitude = video_info.longitude
  308. latitude = video_info.latitude
  309. area = video_info.area
  310. result.append({"area":area,
  311. "status":video_info.status,
  312. "name":video_info.name,
  313. "video_code":video_info.video_code,
  314. # "video_type_label":video_type_label,
  315. "longitude":longitude,
  316. "latitude":latitude})
  317. return {
  318. "code": 200,
  319. "msg": "成功",
  320. "data": result,
  321. 'total':total_items,
  322. "page": page,
  323. "pageSize": pageSize,
  324. "totalPages": totalPages
  325. }
  326. except Exception as e:
  327. traceback.print_exc()
  328. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  329. @router.get('/get_video_transportation_list')
  330. async def get_video_forest_fire_list(
  331. video_type:str = Query(None),
  332. area:str = Query(None),
  333. name:str = Query(None),
  334. db: Session = Depends(get_db),
  335. page: int = Query(1, gt=0, description='页码'),
  336. pageSize: int = Query(10, gt=0, description='每页条目数量'),
  337. body=Depends(remove_xss_json),
  338. user_id=Depends(valid_access_token)):
  339. try:
  340. video_type_list = ['sjyld','sgdfd','jtdd','dzzhyhd']
  341. # video_code_list = [item[0] for item in db.query(TpVideoTag.id).filter(TpVideoTag.dict_value == '4').all()]
  342. video_list = db.query(TPVideoInfo).filter(TPVideoInfo.regionPath.like('@root00000000@44000000002160847111@%'))
  343. if video_type:
  344. if video_type in video_type_list:
  345. lis = [i.video_code for i in db.query(TpVideoTag.video_code).filter(TpVideoTag.dict_value==video_type , TpVideoTag.del_flag =='0').all()]
  346. video_list = video_list.filter(TPVideoInfo.gbIndexCode.in_(lis))
  347. if area:
  348. if area=='直辖市':
  349. lis = [i.video_code for i in db.query(TpVideoLogTransportationAreaInfo.video_code).all()]
  350. video_list = video_list.filter(TPVideoInfo.gbIndexCode.in_(lis))
  351. else:
  352. lis = [i.video_code for i in db.query(TpVideoLogTransportationAreaInfo.video_code).filter(TpVideoLogTransportationAreaInfo.area == area).all()]
  353. video_list = video_list.filter(TPVideoInfo.gbIndexCode.in_(lis))
  354. if name:
  355. video_list = video_list.filter(TPVideoInfo.name.like(f'%{name}%'))
  356. # 计算总条目数
  357. total_items = video_list.count()
  358. # 排序
  359. video_list = video_list.order_by(TPVideoInfo.gbIndexCode)
  360. # 执行分页查询
  361. # print(video_list.offset((page - 1) * pageSize).limit(pageSize))
  362. video_list = video_list.offset((page - 1) * pageSize).limit(pageSize).all()
  363. result = []
  364. # print(total_items,len(video_list),(page - 1) * pageSize,pageSize)
  365. for video_info in video_list:
  366. video_code = video_info.gbIndexCode
  367. video_type_label='其他'
  368. longitude = 0
  369. latitude = 0
  370. area = '直辖市'
  371. video_type_li = db.query(TpVideoTag).filter(TpVideoTag.video_code == video_code,
  372. TpVideoTag.del_flag == '0',TpVideoTag.dict_value.in_(video_type_list)).first()
  373. if video_type_li:
  374. query = db.query(SysDictData)
  375. query = query.filter(SysDictData.del_flag != '2')
  376. query = query.filter(SysDictData.dict_type == 'video_type_8')
  377. query = query.filter(SysDictData.dict_value == video_type_li.dict_value).first()
  378. if query:
  379. video_type_label = query.dict_label
  380. video_base_info = db.query(TpVideoLogTransportationAreaInfo).filter(TpVideoLogTransportationAreaInfo.video_code==video_code).first()
  381. if video_base_info:
  382. longitude = video_base_info.longitude
  383. latitude = video_base_info.latitude
  384. area = video_base_info.area
  385. result.append({"area":area,"status":video_info.status,"name":video_info.name,"video_code":video_code,"video_type_label":video_type_label,"longitude":longitude,"latitude":latitude})
  386. return {
  387. "code": 200,
  388. "msg": "成功",
  389. "data": result,
  390. 'total':total_items,
  391. "page": page,
  392. "pageSize": pageSize,
  393. "totalPages": (total_items + pageSize - 1) // pageSize
  394. }
  395. except Exception as e:
  396. traceback.print_exc()
  397. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  398. @router.get('/get_point_info_transportation_video')
  399. @router.post('/get_point_info_transportation_video')
  400. async def get_video_forest_fire_list(
  401. db: Session = Depends(get_db),
  402. page: int = Query(1, gt=0, description='页码'),
  403. pageSize: int = Query(10, gt=0, description='每页条目数量'),
  404. body=Depends(remove_xss_json),
  405. user_id=Depends(valid_access_token)):
  406. try:
  407. video_type_list = ['sjyld','sgdfd','jtdd','dzzhyhd']
  408. # video_code_list = [item[0] for item in db.query(TpVideoTag.id).filter(TpVideoTag.dict_value == '4').all()]
  409. video_list = db.query(TPVideoInfo).filter(TPVideoInfo.regionPath.like('@root00000000@44000000002160847111@%'))
  410. if 'query' in body:
  411. if 'id' in body['query']:
  412. video_list = video_list.filter(TPVideoInfo.gbIndexCode==body['query']['id'])
  413. # 计算总条目数
  414. total_items = video_list.count()
  415. # 排序
  416. video_list = video_list.order_by(TPVideoInfo.gbIndexCode)
  417. # 执行分页查询
  418. # print(video_list.offset((page - 1) * pageSize).limit(pageSize))
  419. video_list = video_list.offset((page - 1) * pageSize).limit(pageSize).all()
  420. result = []
  421. # print(total_items,len(video_list),(page - 1) * pageSize,pageSize)
  422. for video_info in video_list:
  423. video_code = video_info.gbIndexCode
  424. video_type_label='其他'
  425. longitude = 0
  426. latitude = 0
  427. area = '直辖市'
  428. video_type_li = db.query(TpVideoTag).filter(TpVideoTag.video_code == video_code,
  429. TpVideoTag.del_flag == '0',TpVideoTag.dict_value.in_(video_type_list)).first()
  430. if video_type_li:
  431. query = db.query(SysDictData)
  432. query = query.filter(SysDictData.del_flag != '2')
  433. query = query.filter(SysDictData.dict_type == 'video_type')
  434. query = query.filter(SysDictData.dict_value == video_type_li.dict_value).first()
  435. if query:
  436. video_type_label = query.dict_label
  437. video_base_info = db.query(TpVideoLogTransportationAreaInfo).filter(TpVideoLogTransportationAreaInfo.video_code==video_code).first()
  438. if video_base_info:
  439. longitude = video_base_info.longitude
  440. latitude = video_base_info.latitude
  441. area = video_base_info.area
  442. result.append({"area":area,"status":video_info.status,"name":video_info.name,"video_code":video_info.gbIndexCode,"video_type_label":video_type_label,"longitude":longitude,"latitude":latitude})
  443. return {
  444. "code": 0,
  445. "msg": "success",
  446. "rows": result,
  447. 'total':total_items,
  448. "currentPage": page,
  449. "pageSize": pageSize,
  450. "pages": (total_items + pageSize - 1) // pageSize
  451. }
  452. except Exception as e:
  453. traceback.print_exc()
  454. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  455. @router.get('/transportation/type')
  456. async def get_dict_data_by_type(
  457. db: Session = Depends(get_db),
  458. body = Depends(remove_xss_json),
  459. user_id = Depends(valid_access_token)
  460. ):
  461. try:
  462. # 根据 dict_type 查询字典数据
  463. video_type_list = ['sjyld','sgdfd','jtdd','dzzhyhd']
  464. query = db.query(SysDictData)
  465. query = query.filter(SysDictData.dict_type=='video_type_8')
  466. query = query.filter(SysDictData.dict_value.in_(video_type_list))
  467. query = query.filter(SysDictData.del_flag != '2')
  468. query = query.order_by(SysDictData.dict_sort)
  469. # dict_data = db.query(SysDictData).filter_by(dict_type==dict_type and del_flag != '2').all()
  470. dict_data = query.all()
  471. # 将模型转换为字典
  472. dict_data_list = [
  473. {
  474. "dictCode": d.dict_code,
  475. "dictSort": d.dict_sort,
  476. "dictLabel": d.dict_label,
  477. "dictValue": d.dict_value,
  478. "dictType": d.dict_type,
  479. "cssClass": d.css_class,
  480. "listClass": d.list_class,
  481. "isDefault": d.is_default,
  482. "remark": d.remark,
  483. "createTime": d.create_time.strftime('%Y-%m-%d %H:%M:%S') if d.create_time else ''
  484. }
  485. for d in dict_data
  486. ]
  487. # 构建返回结果
  488. result = {
  489. "code": 200,
  490. "msg": "操作成功",
  491. "data": dict_data_list
  492. }
  493. return result
  494. except Exception as e:
  495. # 处理异常
  496. traceback.print_exc()
  497. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  498. def id_get_region_info(db, indexCode):
  499. query = db.query(TPVideoRegion)
  500. query = query.filter(TPVideoRegion.indexCode == indexCode)
  501. return query.all()
  502. def parent_id_get_region_info(db, parent_id):
  503. query = db.query(TPVideoRegion)
  504. query = query.filter(TPVideoRegion.parentIndexCode == parent_id)
  505. query = query.order_by(TPVideoRegion.sort.asc())
  506. return query.all()
  507. def parent_id_get_video_info(db, unitIndexCode,status):
  508. query = db.query(TPVideoInfo)
  509. query = query.filter(TPVideoInfo.unitIndexCode == unitIndexCode)
  510. query = query.order_by(TPVideoInfo.gbIndexCode.asc())
  511. if status:
  512. query = query.filter(TPVideoInfo.status == status)
  513. return query.all()
  514. def region_path_get_video_info(db, regionPath,status):
  515. query = db.query(TPVideoInfo)
  516. query = query.filter(TPVideoInfo.regionPath.like(f"%{regionPath}%"))
  517. query = query.order_by(TPVideoInfo.gbIndexCode.asc())
  518. if status:
  519. query = query.filter(TPVideoInfo.status == status)
  520. return query.all()
  521. @router.get('/get_video_forest_fire_index_code')
  522. async def get_dict_data_by_type(
  523. db: Session = Depends(get_db)
  524. ):
  525. try:
  526. # 根据 dict_type 查询字典数据
  527. # dict_data = db.query(SysDictData).filter_by(dict_type=dictType).all()
  528. d = parent_id_get_region_info(db, '4409000000216202502')
  529. dict_data_list = [{
  530. "dictCode": data.indexCode,
  531. "dictSort": data.sort,
  532. "dictLabel": data.name,
  533. "dictValue": data.indexCode,
  534. "dictType": '',
  535. "cssClass": '',
  536. "listClass": ''
  537. }for data in d]
  538. # 构建返回结果
  539. result = {
  540. "data": dict_data_list,
  541. "code": 200,
  542. "msg": "查询成功"
  543. }
  544. return result
  545. except Exception as e:
  546. traceback.print_exc()
  547. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  548. @router.get('/get_video_forest_fire_export')
  549. async def get_video_forest_fire_list(
  550. request: Request,
  551. indexCode:str = Query('4409000000216202502'),
  552. status:str = Query(None),
  553. db: Session = Depends(get_db),
  554. user_id: AuthUser = Depends(find_auth_user),
  555. body=Depends(remove_xss_json)):
  556. try:
  557. data = region_path_get_video_info(db, indexCode, status)
  558. data = [{
  559. "摄像头索引码": info.cameraIndexCode,
  560. "国标索引码": info.gbIndexCode,
  561. "摄像头名称": info.name,
  562. "经度": info.longitude,
  563. "纬度": info.latitude,
  564. "海拔": info.altitude,
  565. "像素": info.pixel,
  566. "摄像头类型代码": info.cameraType,
  567. "摄像头类型名称": info.cameraTypeName,
  568. "安装位置": info.installPlace,
  569. "所属组织编号": info.unitIndexCode,
  570. "机构路径": info.regionPath,
  571. "更新时间": info.updateTime,
  572. "创建时间": info.createTime,
  573. "状态码": info.status,
  574. "状态名称": info.statusName
  575. } for info in data]
  576. import pandas as pd
  577. from io import BytesIO
  578. # 将查询结果转换为 DataFrame
  579. df = pd.DataFrame(data)
  580. # 将 DataFrame 导出为 Excel 文件
  581. output = BytesIO()
  582. with pd.ExcelWriter(output, engine='openpyxl') as writer:
  583. df.to_excel(writer, index=False)
  584. # 设置响应头
  585. output.seek(0)
  586. from urllib.parse import quote
  587. encoded_filename = f'森防视频{datetime.now().strftime("%Y%m%d%H%mi%s")}.xlsx'
  588. encoded_filename = quote(encoded_filename, encoding='utf-8')
  589. headers = {
  590. 'Content-Disposition': f'attachment; filename*=UTF-8\'\'{encoded_filename}',
  591. 'Content-Type': 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
  592. }
  593. db_czrz.log(db, user_id, "全域地图", f"全域地图导出森防视频数据成功", request.client.host)
  594. # 返回文件流
  595. return StreamingResponse(output, headers=headers)
  596. except Exception as e:
  597. traceback.print_exc()
  598. return JSONResponse(status_code=500, content={"code": 500, "msg": f"Internal server error: {str(e)}"})
  599. @router.get('/get_video_forest_fire_list')
  600. async def get_video_forest_fire_list(
  601. indexCode:str = Query('4409000000216202502'),
  602. status:str = Query(None),
  603. db: Session = Depends(get_db),
  604. body=Depends(remove_xss_json),
  605. user_id=Depends(valid_access_token)):
  606. try:
  607. """
  608. 根据层级路径构建带有 label 和 children 的树形结构。
  609. :param paths: 包含层级路径的列表
  610. :return: 树形结构的字典
  611. """
  612. "20ba3e565de64df9b29ff70a8056939a"
  613. def build_video_tree(regions, parent_region,online,total,status):
  614. video_tree = []
  615. for region_info in regions:
  616. region = {
  617. "label": region_info.name,
  618. "isLeaf": False,
  619. "status": region_info.status,
  620. "children":[]
  621. }
  622. # print(dept_info.dept_id)
  623. videos = parent_id_get_video_info(db, region_info.indexCode,status)
  624. if len(videos) > 0:
  625. for video_info in videos:
  626. region["children"].append({"label":video_info.name,"status":video_info.status,"video_code":video_info.gbIndexCode,"isLeaf":True})
  627. if video_info.status==1:
  628. online+=1
  629. total += 1
  630. children = parent_id_get_region_info(db, region_info.indexCode)
  631. if len(children) > 0:
  632. children_regions, online, total = build_video_tree(children, region, online, total,status)
  633. region["children"] = children_regions+region["children"]
  634. video_tree.append(region)
  635. return video_tree,online,total
  636. result,online,total = build_video_tree(id_get_region_info(db, indexCode), None,0,0,status)
  637. return {
  638. "code": 200,
  639. "msg": "成功",
  640. "data": result,
  641. 'online':online,
  642. 'total':total
  643. }
  644. #
  645. # video_code_list = [item[0] for item in db.query(TpVideoTag.video_code).filter(TpVideoTag.dict_value == 'slfh').all()]
  646. # # print(video_code_list)
  647. # video_list = db.query(TpVideoLog).filter(TpVideoLog.video_code.in_(video_code_list)).all()
  648. # root = {"label": "Root", "children": [],"online":0,"total":0} # 创建根节点
  649. #
  650. # for video_info in video_list:
  651. # levels = video_info.area.split('/')
  652. # current_node = root
  653. # current_node['total']+=1
  654. # if video_info.status == '在线':
  655. # current_node['online']+=1
  656. # for level in levels:
  657. # # 查找当前层级是否已存在
  658. # existing_node = next((node for node in current_node["children"] if node["label"] == level), None)
  659. # if not existing_node:
  660. # # 如果不存在,创建新节点
  661. # new_node = {"label": level, "children": [],"online":0,"total":0}
  662. # current_node["children"].append(new_node)
  663. # existing_node = new_node
  664. #
  665. # # 移动到子节点
  666. # current_node = existing_node
  667. # current_node['total']+=1
  668. # if video_info.status == '在线':
  669. # current_node['online']+=1
  670. #
  671. # current_node['children'].append({"label":video_info.name,"status":video_info.status,"video_code":video_info.video_code,"isLeaf":True})
  672. #
  673. # return {
  674. # "code": 200,
  675. # "msg": "成功",
  676. # "data": root['children'],
  677. # 'online':root['online'],
  678. # 'total':root['total']
  679. # }
  680. except Exception as e:
  681. traceback.print_exc()
  682. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  683. @router.get('/get_video_tag_info')
  684. async def get_video_tag_info(
  685. video_code:str = Query(None),
  686. db: Session = Depends(get_db),
  687. body=Depends(remove_xss_json),
  688. user_id=Depends(valid_access_token)
  689. ):
  690. try:
  691. tag = []
  692. tag_lable = []
  693. for info in get_video_tag_list(db,video_code):
  694. tag_info = get_dict_data_info(db,'video_type',info.dict_value)
  695. if tag_info:
  696. if tag_info.dict_label not in tag_lable:
  697. tag.append({"id":info.id,
  698. "video_code":video_code,
  699. "dict_type":info.dict_type,
  700. "dict_value":info.dict_value,
  701. "dict_label":tag_info.dict_label,
  702. "dict_code":tag_info.dict_code})
  703. tag_lable.append(tag_info.dict_label)
  704. return {
  705. "code": 200,
  706. "msg": "成功",
  707. "data": tag
  708. }
  709. except Exception as e:
  710. traceback.print_exc()
  711. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  712. @router.post("/add_video_tag")
  713. async def add_video_tag(
  714. user_id=Depends(valid_access_token),
  715. body = Depends(remove_xss_json),
  716. db: Session = Depends(get_db)
  717. ):
  718. try:
  719. tag_info = get_dict_data_info(db, body['dict_type'], body['dict_value'])
  720. if tag_info is None:
  721. return JSONResponse(status_code=404,content={"code":404,"msg":"标签不存在"})
  722. new_video_tag = TpVideoTag(
  723. id = new_guid(),
  724. video_code=body['video_code'],
  725. dict_value=body['dict_value'],
  726. dict_type=body['dict_type'],
  727. create_dept = user_id
  728. )
  729. db.add(new_video_tag)
  730. db.commit()
  731. return {"code": 200, "msg": "新增成功", "data": None}
  732. except Exception as e:
  733. traceback.print_exc()
  734. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  735. @router.post("/add_video_tag_label")
  736. async def add_video_tag(
  737. user_id=Depends(valid_access_token),
  738. body = Depends(remove_xss_json),
  739. db: Session = Depends(get_db)
  740. ):
  741. try:
  742. dict_label = body['dict_label']
  743. dict_info = dict_label_get_dict_data_info(db,body['dict_type'],dict_label)
  744. if dict_info is None:
  745. dict_info = SysDictData(
  746. dict_label=dict_label,
  747. dict_value = new_guid(),
  748. dict_type=body['dict_type'],
  749. list_class = 'default',
  750. create_by = user_id
  751. )
  752. db.add(dict_info)
  753. new_video_tag = TpVideoTag(
  754. id = new_guid(),
  755. video_code=body['video_code'],
  756. dict_value=dict_info.dict_value,
  757. dict_type=body['dict_type'],
  758. create_dept = user_id
  759. )
  760. db.add(new_video_tag)
  761. db.commit()
  762. return {"code": 200, "msg": "新增成功", "data": None}
  763. except Exception as e:
  764. traceback.print_exc()
  765. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  766. @router.delete("/delete_video_tag/{video_tag_id}")
  767. async def delete_video_tag(
  768. video_tag_id: str,
  769. db: Session = Depends(get_db)
  770. ):
  771. try:
  772. # 检查图案是否存在
  773. query = db.query(TpVideoTag)
  774. query = query.filter(TpVideoTag.id == video_tag_id)
  775. query = query.filter(TpVideoTag.del_flag != '2')
  776. video_tag = query.first()
  777. if not video_tag:
  778. return JSONResponse(status_code=404,content={"code":404,"msg":"标签不存在"})
  779. # 执行删除操作
  780. video_tag.del_flag='2'
  781. db.commit()
  782. return {"code": 200, "msg": "删除成功"}
  783. except Exception as e:
  784. traceback.print_exc()
  785. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  786. @router.get('/get_recently_video_tag_info')
  787. async def get_video_tag_info(
  788. # video_code:str = Query(None),
  789. db: Session = Depends(get_db),
  790. body=Depends(remove_xss_json),
  791. page: int = Query(1, gt=0, description='页码'),
  792. pageSize: int = Query(3, gt=0, description='每页条目数量'),
  793. user_id=Depends(valid_access_token)
  794. ):
  795. try:
  796. query = db.query(SysDictData)
  797. query = query.filter(SysDictData.del_flag != '2')
  798. query = query.filter(SysDictData.dict_type == 'video_type')
  799. total_items = query.count()
  800. # 排序
  801. query = query.order_by(SysDictData.create_time.desc())
  802. # 执行分页查询
  803. dicts = query.offset((page - 1) * pageSize).limit(pageSize).all()
  804. tag = []
  805. for info in dicts:
  806. tag.append({
  807. "dict_type":info.dict_type,
  808. "dict_value":info.dict_value,
  809. "dict_label":info.dict_label,
  810. "dict_code":info.dict_code})
  811. return {
  812. "code": 200,
  813. "msg": "成功",
  814. "data": tag,
  815. "total": total_items,
  816. "page": page,
  817. "pageSize": pageSize,
  818. "totalPages": (total_items + pageSize - 1) // pageSize
  819. }
  820. except Exception as e:
  821. traceback.print_exc()
  822. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")
  823. @router.get('/get_lx_hy_video_tag_info')
  824. async def get_lx_hy_video_tag_info(
  825. dict_value:str = Query(None),
  826. type:str= Query(None),
  827. db: Session = Depends(get_db),
  828. body=Depends(remove_xss_json),
  829. page: int = Query(1, gt=0, description='页码'),
  830. pageSize: int = Query(3, gt=0, description='每页条目数量'),
  831. user_id=Depends(valid_access_token)
  832. ):
  833. try:
  834. if dict_value is None or dict_value =='':
  835. query = db.query(SysDictData)
  836. query = query.filter(SysDictData.del_flag != '2')
  837. query = query.filter(SysDictData.dict_type == 'video_type')
  838. if type=='lx':
  839. query_1 = db.query(SysDictData)
  840. query_1 = query_1.filter(SysDictData.del_flag != '2')
  841. query_1 = query_1.filter(SysDictData.dict_type == 'video_tag_type')
  842. elif type == 'hy':
  843. query_1 = db.query(SysDictData)
  844. query_1 = query_1.filter(SysDictData.del_flag != '2')
  845. query_1 = query_1.filter(SysDictData.dict_type == 'video_tag_industry')
  846. else:
  847. return {
  848. "code": 200,
  849. "msg": "成功",
  850. "data": []
  851. }
  852. # for i in query_1.all():
  853. query = query.filter(or_(SysDictData.remark.like(f'%{i.dict_value};%') for i in query_1.all()))
  854. total_items = query.count()
  855. # 排序
  856. query = query.order_by(SysDictData.create_time.desc())
  857. # 执行分页查询
  858. dicts = query.offset((page - 1) * pageSize).limit(pageSize).all()
  859. tag = []
  860. for info in dicts:
  861. tag.append({
  862. "dict_type": info.dict_type,
  863. "dict_value": info.dict_value,
  864. "dict_label": info.dict_label,
  865. "dict_code": info.dict_code})
  866. return {
  867. "code": 200,
  868. "msg": "成功",
  869. "data": tag,
  870. "total": total_items,
  871. "page": page,
  872. "pageSize": pageSize,
  873. "totalPages": (total_items + pageSize - 1) // pageSize
  874. }
  875. query = db.query(SysDictData)
  876. query = query.filter(SysDictData.del_flag != '2')
  877. query = query.filter(SysDictData.dict_type == 'video_type')
  878. query = query.filter(SysDictData.remark.like( f'%{dict_value};%'))
  879. total_items = query.count()
  880. # 排序
  881. query = query.order_by(SysDictData.create_time.desc())
  882. # 执行分页查询
  883. dicts = query.offset((page - 1) * pageSize).limit(pageSize).all()
  884. tag = []
  885. for info in dicts:
  886. tag.append({
  887. "dict_type":info.dict_type,
  888. "dict_value":info.dict_value,
  889. "dict_label":info.dict_label,
  890. "dict_code":info.dict_code})
  891. return {
  892. "code": 200,
  893. "msg": "成功",
  894. "data": tag,
  895. "total": total_items,
  896. "page": page,
  897. "pageSize": pageSize,
  898. "totalPages": (total_items + pageSize - 1) // pageSize
  899. }
  900. except Exception as e:
  901. traceback.print_exc()
  902. raise HTTPException(status_code=500, detail=f"Internal server error: {str(e)}")