BusinessDataController.py 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  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. playMode='could')
  52. upload_duration_qs = vod_hls_qs.values('uid').annotate(uploadFrequency=Count('uid')).order_by(
  53. 'uploadFrequency')
  54. upload_device_count = len(upload_duration_qs) # 上传设备数量
  55. uid_list = []
  56. for item in upload_duration_qs:
  57. item['uploadDuration'] = vod_hls_qs.filter(uid=item['uid']).aggregate(total=Sum('sec'))['total']
  58. item['playDuration'] = video_play_qs.filter(uid=item['uid']).aggregate(total=Sum('duration'))['total']
  59. item['playDuration'] = item['playDuration'] if item['playDuration'] else 0
  60. item['playFrequency'] = video_play_qs.filter(uid=item['uid'], playMode='cloud').count()
  61. uid_list.append(item['uid'])
  62. video_play_qs = video_play_qs.filter(~Q(uid__in=uid_list))
  63. play_duration_qs = video_play_qs.values('uid').annotate(playFrequency=Count('uid')).order_by(
  64. 'playFrequency')
  65. play_device_count = play_duration_qs.count()
  66. for item in play_duration_qs:
  67. item['uploadFrequency'] = 0
  68. item['uploadDuration'] = 0
  69. item['playDuration'] = video_play_qs.filter(uid=item['uid']).aggregate(total=Sum('duration'))['total']
  70. item['playDuration'] = item['playDuration'] if item['playDuration'] else 0
  71. res = {
  72. 'uploadDeviceCount': upload_device_count,
  73. 'playDeviceCount': play_device_count,
  74. 'vodData': list(upload_duration_qs) + list(play_duration_qs)
  75. }
  76. return response.json(0, res)
  77. except Exception as e:
  78. return response.json(500, repr(e))
  79. @classmethod
  80. def query_global_device_vod_business(cls, request, request_dict, response):
  81. """
  82. 查询全球设备云存储数据
  83. @param request:请求
  84. @param request_dict:请求参数
  85. @param response:响应对象
  86. @return:
  87. """
  88. url_list = CommonService.get_domain_name()
  89. try:
  90. headers = {
  91. 'Authorization': request.META.get('HTTP_AUTHORIZATION')
  92. }
  93. upload_device_count = 0
  94. play_device_count = 0
  95. vod_list = []
  96. for url in url_list:
  97. url = url + request.path.replace('global/', '')
  98. res = requests.get(url=url, params=request_dict, headers=headers)
  99. result = res.json()
  100. if result['result_code'] == 0:
  101. upload_device_count += int(result['result']['uploadDeviceCount'])
  102. play_device_count += int(result['result']['playDeviceCount'])
  103. vod_list += result['result']['vodData']
  104. else:
  105. return response.json(result['result_code'])
  106. res = {
  107. 'uploadDeviceCount': upload_device_count,
  108. 'playDeviceCount': play_device_count,
  109. 'vodData': vod_list
  110. }
  111. return response.json(0, res)
  112. except Exception as e:
  113. return response.json(500, repr(e))