BusinessDataController.py 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. # -*- encoding: utf-8 -*-
  2. """
  3. @File : UserDataController.py
  4. @Time : 2022/8/16 10:44
  5. @Author : peng
  6. @Email : zhangdongming@asj6.wecom.work
  7. @Software: PyCharm
  8. """
  9. import requests
  10. from django.db.models import Q, Count, Sum
  11. from django.views.generic.base import View
  12. from Model.models import VodHlsModel, VideoPlaybackTimeModel
  13. from Service.CommonService import CommonService
  14. # 业务数据
  15. class BusinessDataView(View):
  16. def get(self, request, *args, **kwargs):
  17. request.encoding = 'utf-8'
  18. operation = kwargs.get('operation')
  19. return self.validation(request.GET, request, operation)
  20. def post(self, request, *args, **kwargs):
  21. request.encoding = 'utf-8'
  22. operation = kwargs.get('operation')
  23. return self.validation(request.POST, request, operation)
  24. def validation(self, request_dict, request, operation):
  25. token_code, user_id, response = CommonService.verify_token_get_user_id(request_dict, request)
  26. if token_code != 0:
  27. return response.json(token_code)
  28. if operation == 'vodData': # 查询设备云存储数据
  29. return self.query_device_vod_business(request_dict, response)
  30. elif operation == 'global/vodData': # 查询全球设备云存储数据
  31. return self.query_global_device_vod_business(request, request_dict, response)
  32. else:
  33. return response.json(414)
  34. @classmethod
  35. def query_device_vod_business(cls, request_dict, response):
  36. """
  37. 查询设备云存储数据
  38. @param request_dict:请求参数
  39. @request_dict startTime:开始时间
  40. @request_dict endTime:结束时间
  41. @param response:响应对象
  42. @return:
  43. """
  44. start_time = request_dict.get('startTime', None)
  45. end_time = request_dict.get('endTime', None)
  46. if not all([start_time, end_time]):
  47. return response.json(444, {'error param': 'startTime or endTime'})
  48. try:
  49. vod_hls_qs = VodHlsModel.objects.filter(time__range=(start_time, end_time))
  50. video_play_qs = VideoPlaybackTimeModel.objects.filter(startTime__range=(start_time, end_time))
  51. upload_duration_qs = vod_hls_qs.values('uid').annotate(uploadFrequency=Count('uid')).order_by(
  52. 'uploadFrequency')
  53. device_count = len(upload_duration_qs) # 上传设备数量
  54. uid_list = []
  55. for item in upload_duration_qs:
  56. item['uploadDuration'] = vod_hls_qs.filter(uid=item['uid']).aggregate(total=Sum('sec'))['total']
  57. item['playFrequency'] = video_play_qs.filter(uid=item['uid'], playMode='cloud').count()
  58. uid_list.append(item['uid'])
  59. video_play_qs = video_play_qs.filter(~Q(uid__in=uid_list))
  60. play_duration_qs = video_play_qs.values('uid').annotate(playFrequency=Count('uid')).order_by(
  61. 'playFrequency')
  62. for item in play_duration_qs:
  63. item['uploadFrequency'] = 0
  64. item['uploadDuration'] = 0
  65. res = {
  66. 'deviceCount': device_count,
  67. 'vodData': list(upload_duration_qs) + list(play_duration_qs)
  68. }
  69. return response.json(0, res)
  70. except Exception as e:
  71. return response.json(500, repr(e))
  72. @classmethod
  73. def query_global_device_vod_business(cls, request, request_dict, response):
  74. """
  75. 查询全球设备云存储数据
  76. @param request:请求
  77. @param request_dict:请求参数
  78. @param response:响应对象
  79. @return:
  80. """
  81. ap_url = 'https://www.zositechc.cn/dataManagement/businessData/vodData'
  82. as_url = 'https://www.zositecha.com/dataManagement/businessData/vodData'
  83. na_url = 'https://www.dvema.com/dataManagement/businessData/vodData'
  84. eu_url = 'https://www.zositeche.com/dataManagement/businessData/vodData'
  85. local_url = 'http://127.0.0.1:8000/dataManagement/businessData/vodData'
  86. url_list = [local_url]
  87. try:
  88. headers = {
  89. 'Authorization': request.META.get('HTTP_AUTHORIZATION')
  90. }
  91. device_count = 0
  92. vod_list = []
  93. for url in url_list:
  94. res = requests.get(url=url, params=request_dict, headers=headers)
  95. result = res.json()
  96. device_count += int(result['result']['deviceCount'])
  97. vod_list += result['result']['vodData']
  98. res = {
  99. 'deviceCount': device_count,
  100. 'vodData': vod_list
  101. }
  102. return response.json(0, res)
  103. except Exception as e:
  104. return response.json(500, repr(e))