wrjvideo.py 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  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. "addressLongitude": n['addressLongitude'],
  77. "addressLatitude": n['addressLatitude'],
  78. }
  79. # 测试数据
  80. if n['id'] == '1725080256731168770' and settings.IS_PROD == False:
  81. item['status'] = 2
  82. item['status_text'] = '飞行中'
  83. item['fly_info'] = {
  84. "lng": '111.58967074364558', # 当前经度(WGS84)
  85. "lat": '21.5870035628497', # 当前纬度(WGS84)
  86. "windSpeed": '3.0', # 无人机当前接触到的风速(米/ 秒)
  87. "nestSeed": '1.1', # 当前机库所在地风速
  88. "temperature": '34.099998474121094', # 无人机目前舱内温度
  89. "environmentTemperature": '30.4', # 无人机所在地的环境温度
  90. "batteryPerce": '66.0', # 电池电量(%)
  91. "rainFall": '0', # 无人机所在地天气情况 0:无雨 1: 小雨 2: 中雨 3: 大雨
  92. "netWorkRate": 560.0, # 第三方无人机与其平台的网络通 信质量(kb/秒)
  93. "nestSpeed": 0.0, # 当前机库所在地风
  94. }
  95. # 飞行中的附加信息
  96. if str(n['convertCode']) == '2':
  97. fly_info = get_fly_info(n['id'], fly_data)
  98. print('fly_info:', fly_info)
  99. if fly_info is not None:
  100. item['fly_info'] = fly_info
  101. wrj_list.append(item)
  102. '''
  103. sql = "insert into tp_wrj_info (id, name, area, longitude, latitude, address, type) value (:id, :name, :area, :longitude, :latitude, :address, :type)"
  104. db.execute(text(sql), {
  105. "id": n['id'],
  106. "name": n['uavName'],
  107. "area": n['addressAreaId'],
  108. "longitude": n['addressLongitude'],
  109. "latitude": n['addressLatitude'],
  110. "address": n["residentAddress"],
  111. "type": n['status_text']
  112. })
  113. db.commit()
  114. '''
  115. return {
  116. "code": 200,
  117. "msg": "操作成功",
  118. "data": {
  119. "list": wrj_list
  120. }
  121. }
  122. except Exception as e:
  123. traceback.print_exc()
  124. return {
  125. "code": 500,
  126. "msg": "操作失败"
  127. }
  128. def get_fly_info(id: str, data: list):
  129. for n in data:
  130. if n['id'] == id:
  131. return {
  132. "lng": str(n['lng']),
  133. "lat": str(n['lat']),
  134. "windSpeed": str(n['windSpeed']),
  135. "nestSeed": str(n['nestSpeed']),
  136. "temperature": str(n['temperature']),
  137. "environmentTemperature": str(n['environmentTemperature']),
  138. "batteryPerce": str(n['batteryPerce']),
  139. "rainFall": str(n['rainFall'])
  140. }
  141. return None
  142. '''
  143. # 获取飞行中无人机清单
  144. @router.get('/flyUavInfo')
  145. async def flyUavInfo(
  146. db: Session = Depends(get_db),
  147. body=Depends(remove_xss_json)
  148. ):
  149. return {
  150. "code": 200,
  151. "data": [{
  152. "id": "1721437235041120259", # ⽆⼈机ID,⽤于唯⼀标识⼀台⽆⼈机
  153. "uavId": "1720311986430930944", # 三方平台⽆⼈机ID,⽤于唯⼀标识 ⼀台⽆⼈机
  154. "thirdName": None, # 第三方平台名称
  155. "lng": 111.58967074364558, # 当前经度(WGS84)
  156. "lat": 21.5870035628497, # 当前纬度(WGS84)
  157. "flyingTime": None, # ⻜⾏时⻓(秒)
  158. "flyingDistance": 1319.85205078125, # ⻜⾏距离(⽶)
  159. "homeDistance": 1319.85205078125, # 无人机离机库直线距离(⽶)
  160. "height": 149.9, # 相对⾼度/对地⾼度(⽶)
  161. "altitude": 165.49883117675782, # 海拔⾼度(⽶)
  162. "realtimeStatus": 2, # 实时状态。 0:离线 1:待命 2:⻜⾏中
  163. "batteryPerce": 66.0, # 电池电量(%)
  164. "uavHSpeed": 14.85193590075045, # ⽔平速度(⽶/秒)
  165. "uavVSpeed": 0.0, # 垂直速度(⽶/秒)
  166. "pitchAngle": -30.0, # 俯仰⻆
  167. "yawAngle": -149.79347930213842, # 偏航⻆
  168. "hangarStatus": 1, # 机库状态,机库无⼈机必填 0:离线 1:在线
  169. "netWorkRate": 560.0, # 第三方无人机与其平台的网络通 信质量(kb/秒)
  170. "rainFall": 0, # 无人机所在地天气情况 0:无雨 1: 小雨 2: 中雨 3: 大雨
  171. "windSpeed": None, # 无人机当前接触到的风速(米/ 秒)
  172. "nestSpeed": 0.0, # 当前机库所在地风速
  173. "temperature": 34.099998474121094, # 无人机目前舱内温度(unit:℃)
  174. "environmentTemperature": 30.4, # 无人机所在地的环境温度(unit: ℃)
  175. "upQuality": 80.0, # 无人机与平台的通信质量(unit:%)
  176. "downQuality": 80.0, # 平台与无人机的通信质量(unit:%)
  177. "statusInfoTime": 1728544749103, # 实时消息对应时间
  178. "thirdPartId": "9b627ed9f7704e109fe22356d72b14ca" # 平台ID,只用于平台内部传值,不用于对外
  179. }],
  180. "msg": "操作成功"
  181. }
  182. try:
  183. data = WRJApi.flyUavInfo()
  184. return {
  185. "code": 200,
  186. "msg": "操作成功",
  187. "data": data
  188. }
  189. except Exception as e:
  190. return {
  191. "code": 500,
  192. "msg": "操作失败"
  193. }
  194. # 获取无人机实时飞行信息
  195. @router.get('/getRealInfo')
  196. async def getRealInfo(
  197. sn: str,
  198. db: Session = Depends(get_db),
  199. body = Depends(remove_xss_json)
  200. ):
  201. return {
  202. "code": 200,
  203. "data": {
  204. "id": "",
  205. "thirdPartformUavId": "第三方平台无人机id【sn】",
  206. "thirdPlartformId": "第三方平台id",
  207. "thirdName": "第三方平台名称",
  208. "flyingTime": "飞行时长",
  209. "flyingDistance":"飞行距离",
  210. "uavName": "无人机名称",
  211. "uavBrand": "无人机品牌",
  212. "realtimeStatus": "无人机实时状态",
  213. "height": "高度",
  214. "horizontalSpeed":"水平速度",
  215. "verticalSpeed":"垂直速度",
  216. "orgId":"所属单位",
  217. "orgName":"所属单位名称",
  218. "orgPath":"所属单位层级全路径",
  219. "orgTypeId":"单位类型id",
  220. "orgTypeName":"单位类型名称",
  221. "areaId":"所属行政辖区",
  222. "areaName":"所属行政辖区名称",
  223. "dataSource":"数据来源 1.本地创建 2.第三方平台",
  224. "addressLongitude":"常驻地址经度",
  225. "addressLatitude":"常驻地址维度",
  226. "latitude":"实时纬度",
  227. "longitude":"实时经度",
  228. "currentLocation":"当前位置信息",
  229. "addressLocation":"常驻地位置信息",
  230. "constructionModel":"建设模式 0-财政资金采购 (硬件) 1-财政资金采购 (服务) 2-社会资源",
  231. "dispatchResponseTime":"调度响应时间 0-15分钟内 1-2小时内 2-半天内 3-1天以上",
  232. "isHangarControl":"配置机巢/机库/基站控制 0-否 1-是",
  233. "thirdPullStreamAddress":"第三方平台流媒体拉流地址",
  234. "mediaPullStreamAddress":"流媒体拉流地址",
  235. "mediaPullType":"流媒体拉流方式 (rtmp、rtsp、flv、gb28181)",
  236. "nestOutMediaPullStreamAddress":"机舱外流媒体拉流地址",
  237. "nestOutMediaPullType": "机舱外流媒体拉流拉流方式:rtmp、rtsp、flv、gb28181",
  238. "thirdNestOutPullStreamAddress":"第三方平台机巢外部视频拉流地址"
  239. },
  240. "msg": "操作成功"
  241. }
  242. try:
  243. data = WRJApi.getRealInfo(sn)
  244. return {
  245. "code": 200,
  246. "msg": "操作成功",
  247. "data": data
  248. }
  249. except Exception as e:
  250. return {
  251. "code": 500,
  252. "msg": "操作失败"
  253. }'
  254. '''