wrjvideo.py 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. from fastapi import APIRouter, Request, Depends,Query,HTTPException
  4. from typing import Union
  5. from database import get_db
  6. from sqlalchemy.orm import Session
  7. from sqlalchemy import case,or_
  8. from sqlalchemy import text
  9. from utils import *
  10. from utils.ry_system_util import *
  11. from utils.video_util import *
  12. from common.security import valid_access_token
  13. from fastapi.responses import JSONResponse
  14. import traceback
  15. from datetime import datetime
  16. from common import WRJApi
  17. from config import settings
  18. router = APIRouter()
  19. # 获取无人机清单
  20. @router.get('/roughTimeStatus')
  21. async def roughTimeStatus(
  22. area: str = '',
  23. keyword: str = '',
  24. time: str = '',
  25. mode: str = '',
  26. type: str = '',
  27. status: str = '',
  28. db: Session = Depends(get_db)
  29. ):
  30. try:
  31. print('area:', area)
  32. print('keyword:', keyword)
  33. print('time:', time)
  34. print('mode:', mode)
  35. print('type:', type)
  36. print('status:', status)
  37. fly_data = WRJApi.flyUavInfo()
  38. data = WRJApi.roughTimeStatus()
  39. area_code = ''
  40. status_list = status.split(',')
  41. mode_list = mode.split(',')
  42. type_list = type.split(',')
  43. if area != '':
  44. row = db.query(GovdataArea).filter(GovdataArea.id == int(area)).first()
  45. area_code = row.area_code.rstrip('0')
  46. convertDict = { "0": "离线", "1": "待命", "2": "飞行中", "3": "管制中", "4": "维护中", "5": "执行任务" }
  47. wrj_list = []
  48. for n in data:
  49. if area_code != '' and n['addressAreaId'].startswith(area_code) == False:
  50. continue
  51. if keyword != '' and n['uavName'].find(keyword) == -1:
  52. continue
  53. # 调度响应时间 0-半小时内 1-1小时内 2-2小时内 3-4小时内 4-8小时内 5-24小时内 6-24小时外
  54. if time != '' and n['dispatchResponseTime'] != int(time):
  55. continue
  56. # 建设模式 0-财政资金采购 (硬件) 1-财政资金采购 (服务) 2-社会面资源 3-示范地区补点
  57. if mode != '' and str(n['constructionModel']) not in mode_list:
  58. continue
  59. # "isHangarControl": 1 // 配置机巢/机库/基站控制 0-否 1-是
  60. if type != '' and str(n['isHangarControl']) not in type_list:
  61. continue
  62. # "convertCode": null, // // 第三方机库的状态 0-离线、1-待命中、2-飞行中、3-管制中、4-维护中、5-执行任务
  63. if status != '' and str(n['convertCode']) not in status_list:
  64. continue
  65. n['status_text'] = convertDict[str(n['convertCode'])]
  66. item = {
  67. "id": n['id'],
  68. "drone_name": n['uavName'],
  69. "status": n['convertCode'],
  70. "status_text": n['status_text'],
  71. "time": n['dispatchResponseTime'],
  72. "mode": n['constructionModel'],
  73. "type": n['isHangarControl'],
  74. "fly_url": n['mediaPullStreamAddress'] if n['mediaPullStreamAddress'] is not None else "", # 飞机视频流
  75. "nest_url": n['nestOutMediaPullStreamAddress'] if n['nestOutMediaPullStreamAddress'] is not None else "", # 机巢视频流
  76. }
  77. # 测试数据
  78. if n['id'] == '1725080256731168770' and settings.IS_PROD == False:
  79. item['status'] = 2
  80. item['status_text'] = '飞行中'
  81. item['fly_info'] = {
  82. "lng": '111.58967074364558', # 当前经度(WGS84)
  83. "lat": '21.5870035628497', # 当前纬度(WGS84)
  84. "windSpeed": '3.0', # 无人机当前接触到的风速(米/ 秒)
  85. "nestSeed": '1.1', # 当前机库所在地风速
  86. "temperature": '34.099998474121094', # 无人机目前舱内温度
  87. "environmentTemperature": '30.4', # 无人机所在地的环境温度
  88. "batteryPerce": '66.0', # 电池电量(%)
  89. "rainFall": '0', # 无人机所在地天气情况 0:无雨 1: 小雨 2: 中雨 3: 大雨
  90. "netWorkRate": 560.0, # 第三方无人机与其平台的网络通 信质量(kb/秒)
  91. "nestSpeed": 0.0, # 当前机库所在地风
  92. }
  93. # 飞行中的附加信息
  94. if str(n['convertCode']) == '2':
  95. fly_info = get_fly_info(n['id'], fly_data)
  96. print('fly_info:', fly_info)
  97. if fly_info is not None:
  98. item['fly_info'] = fly_info
  99. wrj_list.append(item)
  100. return {
  101. "code": 200,
  102. "msg": "操作成功",
  103. "data": {
  104. "list": wrj_list
  105. }
  106. }
  107. except Exception as e:
  108. traceback.print_exc()
  109. return {
  110. "code": 500,
  111. "msg": "操作失败"
  112. }
  113. def get_fly_info(id: str, data: list):
  114. for n in data:
  115. if n['id'] == id:
  116. return {
  117. "lng": str(n['lng']),
  118. "lat": str(n['lat']),
  119. "windSpeed": str(n['windSpeed']),
  120. "nestSeed": str(n['nestSpeed']),
  121. "temperature": str(n['temperature']),
  122. "environmentTemperature": str(n['environmentTemperature']),
  123. "batteryPerce": str(n['batteryPerce']),
  124. "rainFall": str(n['rainFall'])
  125. }
  126. return None
  127. '''
  128. # 获取飞行中无人机清单
  129. @router.get('/flyUavInfo')
  130. async def flyUavInfo(
  131. db: Session = Depends(get_db),
  132. body=Depends(remove_xss_json)
  133. ):
  134. return {
  135. "code": 200,
  136. "data": [{
  137. "id": "1721437235041120259", # ⽆⼈机ID,⽤于唯⼀标识⼀台⽆⼈机
  138. "uavId": "1720311986430930944", # 三方平台⽆⼈机ID,⽤于唯⼀标识 ⼀台⽆⼈机
  139. "thirdName": None, # 第三方平台名称
  140. "lng": 111.58967074364558, # 当前经度(WGS84)
  141. "lat": 21.5870035628497, # 当前纬度(WGS84)
  142. "flyingTime": None, # ⻜⾏时⻓(秒)
  143. "flyingDistance": 1319.85205078125, # ⻜⾏距离(⽶)
  144. "homeDistance": 1319.85205078125, # 无人机离机库直线距离(⽶)
  145. "height": 149.9, # 相对⾼度/对地⾼度(⽶)
  146. "altitude": 165.49883117675782, # 海拔⾼度(⽶)
  147. "realtimeStatus": 2, # 实时状态。 0:离线 1:待命 2:⻜⾏中
  148. "batteryPerce": 66.0, # 电池电量(%)
  149. "uavHSpeed": 14.85193590075045, # ⽔平速度(⽶/秒)
  150. "uavVSpeed": 0.0, # 垂直速度(⽶/秒)
  151. "pitchAngle": -30.0, # 俯仰⻆
  152. "yawAngle": -149.79347930213842, # 偏航⻆
  153. "hangarStatus": 1, # 机库状态,机库无⼈机必填 0:离线 1:在线
  154. "netWorkRate": 560.0, # 第三方无人机与其平台的网络通 信质量(kb/秒)
  155. "rainFall": 0, # 无人机所在地天气情况 0:无雨 1: 小雨 2: 中雨 3: 大雨
  156. "windSpeed": None, # 无人机当前接触到的风速(米/ 秒)
  157. "nestSpeed": 0.0, # 当前机库所在地风速
  158. "temperature": 34.099998474121094, # 无人机目前舱内温度(unit:℃)
  159. "environmentTemperature": 30.4, # 无人机所在地的环境温度(unit: ℃)
  160. "upQuality": 80.0, # 无人机与平台的通信质量(unit:%)
  161. "downQuality": 80.0, # 平台与无人机的通信质量(unit:%)
  162. "statusInfoTime": 1728544749103, # 实时消息对应时间
  163. "thirdPartId": "9b627ed9f7704e109fe22356d72b14ca" # 平台ID,只用于平台内部传值,不用于对外
  164. }],
  165. "msg": "操作成功"
  166. }
  167. try:
  168. data = WRJApi.flyUavInfo()
  169. return {
  170. "code": 200,
  171. "msg": "操作成功",
  172. "data": data
  173. }
  174. except Exception as e:
  175. return {
  176. "code": 500,
  177. "msg": "操作失败"
  178. }
  179. # 获取无人机实时飞行信息
  180. @router.get('/getRealInfo')
  181. async def getRealInfo(
  182. sn: str,
  183. db: Session = Depends(get_db),
  184. body = Depends(remove_xss_json)
  185. ):
  186. return {
  187. "code": 200,
  188. "data": {
  189. "id": "",
  190. "thirdPartformUavId": "第三方平台无人机id【sn】",
  191. "thirdPlartformId": "第三方平台id",
  192. "thirdName": "第三方平台名称",
  193. "flyingTime": "飞行时长",
  194. "flyingDistance":"飞行距离",
  195. "uavName": "无人机名称",
  196. "uavBrand": "无人机品牌",
  197. "realtimeStatus": "无人机实时状态",
  198. "height": "高度",
  199. "horizontalSpeed":"水平速度",
  200. "verticalSpeed":"垂直速度",
  201. "orgId":"所属单位",
  202. "orgName":"所属单位名称",
  203. "orgPath":"所属单位层级全路径",
  204. "orgTypeId":"单位类型id",
  205. "orgTypeName":"单位类型名称",
  206. "areaId":"所属行政辖区",
  207. "areaName":"所属行政辖区名称",
  208. "dataSource":"数据来源 1.本地创建 2.第三方平台",
  209. "addressLongitude":"常驻地址经度",
  210. "addressLatitude":"常驻地址维度",
  211. "latitude":"实时纬度",
  212. "longitude":"实时经度",
  213. "currentLocation":"当前位置信息",
  214. "addressLocation":"常驻地位置信息",
  215. "constructionModel":"建设模式 0-财政资金采购 (硬件) 1-财政资金采购 (服务) 2-社会资源",
  216. "dispatchResponseTime":"调度响应时间 0-15分钟内 1-2小时内 2-半天内 3-1天以上",
  217. "isHangarControl":"配置机巢/机库/基站控制 0-否 1-是",
  218. "thirdPullStreamAddress":"第三方平台流媒体拉流地址",
  219. "mediaPullStreamAddress":"流媒体拉流地址",
  220. "mediaPullType":"流媒体拉流方式 (rtmp、rtsp、flv、gb28181)",
  221. "nestOutMediaPullStreamAddress":"机舱外流媒体拉流地址",
  222. "nestOutMediaPullType": "机舱外流媒体拉流拉流方式:rtmp、rtsp、flv、gb28181",
  223. "thirdNestOutPullStreamAddress":"第三方平台机巢外部视频拉流地址"
  224. },
  225. "msg": "操作成功"
  226. }
  227. try:
  228. data = WRJApi.getRealInfo(sn)
  229. return {
  230. "code": 200,
  231. "msg": "操作成功",
  232. "data": data
  233. }
  234. except Exception as e:
  235. return {
  236. "code": 500,
  237. "msg": "操作失败"
  238. }'
  239. '''