BusinessDataController.py 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  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. url_list = CommonService.get_domain_name()
  82. try:
  83. headers = {
  84. 'Authorization': request.META.get('HTTP_AUTHORIZATION')
  85. }
  86. device_count = 0
  87. vod_list = []
  88. for url in url_list:
  89. url = url + request.path.replace('global/', '')
  90. res = requests.get(url=url, params=request_dict, headers=headers)
  91. result = res.json()
  92. if result['result_code'] == 0:
  93. device_count += int(result['result']['deviceCount'])
  94. vod_list += result['result']['vodData']
  95. else:
  96. return response.json(result['result_code'])
  97. res = {
  98. 'deviceCount': device_count,
  99. 'vodData': vod_list
  100. }
  101. return response.json(0, res)
  102. except Exception as e:
  103. return response.json(500, repr(e))