KVSController.py 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351
  1. # -*- coding: utf-8 -*-
  2. """
  3. @Author : Rocky
  4. @Time : 2022/10/18 9:48
  5. @File :KVSController.py
  6. """
  7. import hashlib
  8. import time
  9. import uuid
  10. import datetime
  11. import pytz
  12. from django.views import View
  13. from Model.models import KVS, Device_User, Device_Info
  14. from Object.AWS.AmazonKVSUtil import AmazonKVSObject
  15. from Object.AWS.AmazonKinesisVideoUtil import AmazonKinesisVideoObject, AmazonKVAMObject
  16. from Object.RedisObject import RedisObject
  17. from Object.ResponseObject import ResponseObject
  18. from Ansjer.config import ACCESS_KEY_ID, SECRET_ACCESS_KEY, REGION_NAME, SERVER_DOMAIN
  19. from Object.TokenObject import TokenObject
  20. from Service.CommonService import CommonService
  21. class UserRelatedView(View):
  22. def get(self, request, *args, **kwargs):
  23. request.encoding = 'utf-8'
  24. operation = kwargs.get('operation')
  25. return self.validation(request.GET, operation, request)
  26. def post(self, request, *args, **kwargs):
  27. request.encoding = 'utf-8'
  28. operation = kwargs.get('operation')
  29. return self.validation(request.POST, operation, request)
  30. def validation(self, request_dict, operation, request):
  31. response = ResponseObject()
  32. if operation == 'generate-qr-code': # 网页生成二维码
  33. return self.generate_qr_code(request_dict, response)
  34. elif operation == 'web-login': # 网页登录
  35. return self.web_login(request_dict, request, response)
  36. elif operation == 'confirm-login': # app确认登录
  37. return self.confirm_login(request_dict, response)
  38. else:
  39. tko = TokenObject(
  40. request.META.get('HTTP_AUTHORIZATION'),
  41. returntpye='pc')
  42. if tko.code != 0:
  43. return response.json(tko.code)
  44. response.lang = tko.lang
  45. user_id = tko.userID
  46. if operation == 'get-device': # 获取设备列表
  47. return self.get_device(request_dict, response, user_id)
  48. else:
  49. return response.json(404)
  50. @staticmethod
  51. def generate_qr_code(request_dict, response):
  52. """
  53. 网页生成二维码
  54. @param request_dict: 请求参数
  55. @param response: 响应对象
  56. @return: response
  57. """
  58. nwo_time = time.time()
  59. redis_obj = RedisObject()
  60. try:
  61. uuid_number = hashlib.md5((str(uuid.uuid1()) + str(nwo_time)).encode('utf-8')).hexdigest()
  62. flag = redis_obj.set_ex_data(uuid_number, 0, 300)
  63. res = {'type': 'autologin', 'id': uuid_number}
  64. if flag:
  65. return response.json(0, res)
  66. else:
  67. return response.json(119)
  68. except Exception as e:
  69. print(e)
  70. return response.json(500)
  71. @staticmethod
  72. def web_login(request_dict, request, response):
  73. """
  74. 网页登录
  75. @param request_dict: 请求参数
  76. @request_dict serial_number: 序列号
  77. @param response: 响应对象
  78. @return: response
  79. """
  80. uuid_number = request_dict.get('uuid', None)
  81. if not uuid_number:
  82. return response.json(444, {'error param': 'uuid'})
  83. try:
  84. redis_obj = RedisObject()
  85. status = redis_obj.get_data(uuid_number)
  86. if status == '0':
  87. return response.json(18)
  88. elif status is False:
  89. return response.json(119)
  90. redis_obj.del_data(uuid_number)
  91. tko = TokenObject(status, returntpye='pc')
  92. response.lang = tko.lang
  93. if tko.code != 0:
  94. return response.json(tko.code)
  95. user_id = tko.userID
  96. device_user_qs = Device_User.objects.filter(userID=user_id).values('NickName', 'userIconPath',
  97. 'userIconUrl')
  98. if not device_user_qs.exists():
  99. user_icon_url = ''
  100. nick_name = ''
  101. else:
  102. users = device_user_qs.first()
  103. nick_name = users['NickName']
  104. user_icon_path = str(users['userIconPath'])
  105. if user_icon_path:
  106. user_icon_path = user_icon_path.replace('static/', '').replace('\\', '/')
  107. user_icon_url = SERVER_DOMAIN + 'account/getAvatar/' + user_icon_path
  108. else:
  109. user_icon_url = ''
  110. return response.json(0, {'token': status, 'userIconUrl': user_icon_url, 'nickName': nick_name})
  111. except Exception as e:
  112. print(e)
  113. return response.json(500)
  114. @staticmethod
  115. def confirm_login(request_dict, response):
  116. """
  117. app确认登录
  118. @param request_dict: 请求参数
  119. @request_dict serial_number: 序列号
  120. @param response: 响应对象
  121. @return: response
  122. """
  123. uuid_number = request_dict.get('uuid', None)
  124. token = request_dict.get('token', None)
  125. if not all([uuid_number, token]):
  126. return response.json(444, {'error param': 'uuid or token'})
  127. redis_obj = RedisObject()
  128. try:
  129. status = redis_obj.get_data(uuid_number)
  130. if status is False:
  131. return response.json(119)
  132. flag = redis_obj.set_ex_data(uuid_number, token, 300)
  133. if flag is False:
  134. return response.json(309)
  135. return response.json(0)
  136. except Exception as e:
  137. print(e)
  138. return response.json(500)
  139. @staticmethod
  140. def get_device(request_dict, response, user_id):
  141. """
  142. 获取设备列表
  143. @param request_dict: 请求参数
  144. @param response: 响应对象
  145. @param user_id: 用户id
  146. @return: response
  147. """
  148. try:
  149. device_qs = Device_Info.objects.filter(userID=user_id).values('serial_number', 'NickName')
  150. return response.json(0, list(device_qs))
  151. except Exception as e:
  152. print(e)
  153. return response.json(500)
  154. class KVSView(View):
  155. def get(self, request, *args, **kwargs):
  156. request.encoding = 'utf-8'
  157. operation = kwargs.get('operation')
  158. return self.validation(request.GET, request, operation)
  159. def post(self, request, *args, **kwargs):
  160. request.encoding = 'utf-8'
  161. operation = kwargs.get('operation')
  162. return self.validation(request.POST, request, operation)
  163. def validation(self, request_dict, request, operation):
  164. response = ResponseObject()
  165. if operation == 'create-media': # 创建视频流
  166. return self.create_media(request_dict, response)
  167. elif operation == 'update-data-retention': # 修改视频流数据保留时间
  168. return self.update_data_retention(request_dict, response)
  169. elif operation == 'get-hls-midea': # 获取视频播放地址
  170. return self.get_hls_midea_url(request_dict, response)
  171. else:
  172. tko = TokenObject(
  173. request.META.get('HTTP_AUTHORIZATION'),
  174. returntpye='pc')
  175. if tko.code != 0:
  176. return response.json(tko.code)
  177. response.lang = tko.lang
  178. user_id = tko.userID
  179. if operation == 'get-device-midea-list': # 获取设备列表
  180. return self.get_device_midea_list(request_dict, response)
  181. else:
  182. return response.json(404)
  183. @staticmethod
  184. def create_media(request_dict, response):
  185. """
  186. 创建视频流
  187. @param request_dict: 请求参数
  188. @request_dict serial_number: 序列号
  189. @param response: 响应对象
  190. @return: response
  191. """
  192. serial_number = request_dict.get('serial_number', None)
  193. try:
  194. kvs_qs = KVS.objects.filter(stream_name=serial_number)
  195. if kvs_qs.exists():
  196. return response.json(174)
  197. kinesis_video_obj = AmazonKinesisVideoObject(
  198. aws_access_key_id=ACCESS_KEY_ID,
  199. secret_access_key=SECRET_ACCESS_KEY,
  200. region_name=REGION_NAME
  201. )
  202. stream_arn = kinesis_video_obj.create_stream(stream_name=serial_number)
  203. if stream_arn:
  204. now_time = int(time.time())
  205. KVS.objects.create(stream_name=serial_number, stream_arn=stream_arn, created_time=now_time,
  206. updated_time=now_time)
  207. return response.json(0)
  208. else:
  209. return response.json(178)
  210. except Exception as e:
  211. print(e)
  212. return response.json(500)
  213. @staticmethod
  214. def update_data_retention(request_dict, response):
  215. """
  216. 修改视频流数据保留时间
  217. @param request_dict: 请求参数
  218. @request_dict serial_number: 序列号
  219. @request_dict operation: 操作,增加/减少
  220. @request_dict data_retention_change_in_hours: 修改的时间
  221. @param response: 响应对象
  222. @return: response
  223. """
  224. serial_number = request_dict.get('serial_number', None)
  225. operation = request_dict.get('operation', None)
  226. data_retention_change_in_hours = request_dict.get('data_retention_change_in_hours', None)
  227. try:
  228. kvs_qs = KVS.objects.filter(stream_name=serial_number)
  229. if not kvs_qs.exists():
  230. return response.json(174)
  231. kinesis_video_obj = AmazonKinesisVideoObject(
  232. aws_access_key_id=ACCESS_KEY_ID,
  233. secret_access_key=SECRET_ACCESS_KEY,
  234. region_name=REGION_NAME
  235. )
  236. now_time = int(time.time())
  237. data_retention_change_in_hours = int(data_retention_change_in_hours)
  238. kinesis_video_obj.update_data_retention(stream_name=serial_number, operation=operation,
  239. data_retention_change_in_hours=data_retention_change_in_hours)
  240. kvs_qs.update(data_retention_in_hours=data_retention_change_in_hours, updated_time=now_time)
  241. return response.json(0)
  242. except Exception as e:
  243. print(e)
  244. return response.json(500)
  245. @staticmethod
  246. def get_hls_midea_url(request_dict, response):
  247. """
  248. 获取视频播放地址
  249. @param request_dict: 请求参数
  250. @request_dict serial_number: 序列号
  251. @request_dict startTime: 开始时间
  252. @request_dict endTime: 结束时间
  253. @param response: 响应对象
  254. @return: response
  255. """
  256. serial_number = request_dict.get('serial_number', None)
  257. start_time = request_dict.get('startTime', None)
  258. end_time = request_dict.get('endTime', None)
  259. if not all([serial_number, start_time, end_time]):
  260. return response.json(444)
  261. start_time = datetime.datetime.fromtimestamp(int(start_time)).astimezone(pytz.utc)
  262. end_time = datetime.datetime.fromtimestamp(int(end_time)).astimezone(pytz.utc)
  263. try:
  264. # kvs_qs = KVS.objects.filter(stream_name=serial_number)
  265. # if not kvs_qs.exists():
  266. # return response.json(174)
  267. kinesis_video_obj = AmazonKVAMObject(
  268. aws_access_key_id='AKIA2E67UIMD45Y3HL53',
  269. secret_access_key='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',
  270. region_name='us-east-1',
  271. stream_name=serial_number,
  272. api_name='GET_HLS_STREAMING_SESSION_URL'
  273. )
  274. hls_streaming_session_url = kinesis_video_obj.get_hls_streaming_session_url(serial_number, start_time,
  275. end_time)
  276. return response.json(0, {"HlsStreamingSessionUrl": hls_streaming_session_url})
  277. except Exception as e:
  278. print(e)
  279. return response.json(500, repr(e))
  280. @staticmethod
  281. def get_device_midea_list(request_dict, response):
  282. """
  283. 获取视频播放列表
  284. @param request_dict: 请求参数
  285. @request_dict serial_number: 序列号
  286. @request_dict startTime: 开始时间
  287. @request_dict endTime: 结束时间
  288. @param response: 响应对象
  289. @return: response
  290. """
  291. serial_number = request_dict.get('serial_number', None)
  292. start_time = request_dict.get('startTime', None)
  293. end_time = request_dict.get('endTime', None)
  294. page = request_dict.get('page', None)
  295. size = request_dict.get('size', None)
  296. if not all([serial_number, start_time, end_time, page, size]):
  297. return response.json(444)
  298. page = int(page)
  299. size = int(size)
  300. start_time = datetime.datetime.fromtimestamp(int(start_time)).astimezone(pytz.utc)
  301. end_time = datetime.datetime.fromtimestamp(int(end_time)).astimezone(pytz.utc)
  302. try:
  303. # kvs_qs = KVS.objects.filter(stream_name=serial_number)
  304. # if not kvs_qs.exists():
  305. # return response.json(174)
  306. kinesis_fragments_obj = AmazonKVAMObject(
  307. aws_access_key_id='AKIA2E67UIMD45Y3HL53',
  308. secret_access_key='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',
  309. region_name='us-east-1',
  310. stream_name=serial_number,
  311. api_name='LIST_FRAGMENTS'
  312. )
  313. kinesis_images_obj = AmazonKVAMObject(
  314. aws_access_key_id='AKIA2E67UIMD45Y3HL53',
  315. secret_access_key='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',
  316. region_name='us-east-1',
  317. stream_name=serial_number,
  318. api_name='GET_IMAGES'
  319. )
  320. stream_list = kinesis_fragments_obj.get_list_fragments(serial_number, start_time, end_time)[
  321. (page - 1) * size:page * size]
  322. for item in stream_list:
  323. temp_start_time = item['startTime'].astimezone(pytz.utc)
  324. temp_end_time = temp_start_time + datetime.timedelta(seconds=300)
  325. item['image'] = kinesis_images_obj.get_images(serial_number, temp_start_time, temp_end_time)
  326. item['startTime'] = int(time.mktime(item['startTime'].timetuple()))
  327. item['endTime'] = int(time.mktime(item['endTime'].timetuple()))
  328. return response.json(0, stream_list)
  329. except Exception as e:
  330. print(e)
  331. return response.json(500, repr(e))