videoinfo.py 39 KB

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