IcloudService.py 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. # -*- coding: utf-8 -*-
  2. """
  3. @Author : peng
  4. @Time : 2023-6-7 18:26:35
  5. @File :IcloudMeal.py
  6. """
  7. import time
  8. from django.db.models import Sum, Q
  9. from django.http import HttpResponse
  10. from django.views import View
  11. from Model.models import IcloudUseDetails, IcloudService, VodBucketModel, IcloudStorageRecord, Device_Info
  12. from Object.AWS.AmazonS3Util import AmazonS3Util
  13. from Object.RedisObject import RedisObject
  14. from Object.ResponseObject import ResponseObject
  15. from Object.TokenObject import TokenObject
  16. from Ansjer.config import ACCESS_KEY_ID, SECRET_ACCESS_KEY, REGION_NAME, SERVER_DOMAIN, AWS_ACCESS_KEY_ID, \
  17. AWS_SECRET_ACCESS_KEY
  18. from Service.VodHlsService import SplitVodHlsObject
  19. class IcloudServiceView(View):
  20. def get(self, request, *args, **kwargs):
  21. request.encoding = 'utf-8'
  22. operation = kwargs.get('operation')
  23. return self.validation(request.GET, operation, request)
  24. def post(self, request, *args, **kwargs):
  25. request.encoding = 'utf-8'
  26. operation = kwargs.get('operation')
  27. return self.validation(request.POST, operation, request)
  28. def validation(self, request_dict, operation, request):
  29. response = ResponseObject()
  30. tko = TokenObject(request.META.get('HTTP_AUTHORIZATION'))
  31. response.lang = tko.lang
  32. user_id = tko.userID
  33. if tko.code != 0:
  34. return response.json(tko.code)
  35. if operation == 'vodUpload': # 云存上传云盘
  36. return self.vod_upload(request_dict, response, user_id)
  37. elif operation == 'get-scanning-status': # 确认app是否扫码
  38. return self.get_scanning_status(request_dict, response)
  39. else:
  40. return response.json(404)
  41. @staticmethod
  42. def vod_upload(request_dict, response, user_id):
  43. """
  44. 云存上传云盘
  45. @param request_dict: 请求参数
  46. @param user_id: 用户id
  47. @request_dict serial_number: 序列号
  48. @param response: 响应对象
  49. @return: response
  50. """
  51. uid = request_dict.get('uid', None)
  52. channel = request_dict.get('channel', None)
  53. start_time = request_dict.get('start_time', None)
  54. if not all([uid, channel, start_time]):
  55. return response.json(444, {'error param': 'uid,channel,start_time'})
  56. device_qs = Device_Info.objects.filter(UID=uid, userID=user_id).values('NickName')
  57. if not device_qs.exists():
  58. return response.json(173)
  59. # 查询是否开通云盘
  60. use_details_qs = IcloudUseDetails.objects.filter(user_id=user_id).values('id', 'bucket_id', 'use_size')
  61. if not use_details_qs.exists():
  62. return response.json(173)
  63. use_details_id = use_details_qs[0]['id']
  64. bucket_id = use_details_qs[0]['bucket_id']
  65. use_size = use_details_qs[0]['use_size']
  66. now_time = int(time.time())
  67. nickname = device_qs[0]['NickName']
  68. # 判断云盘是否还有容量
  69. all_size = IcloudService.objects.filter(Q(use_details_id=use_details_id), Q(use_status=0),
  70. Q(end_time__gt=now_time) | Q(end_time=0)).values(
  71. 'size').aggregate(total_size=Sum('count'))['total_size']
  72. all_size = all_size if all_size else 0
  73. if use_size > all_size:
  74. return response.json(910)
  75. split_vod_hls_obj = SplitVodHlsObject()
  76. vod_hls = split_vod_hls_obj.get_vod_hls_data(uid=uid, channel=channel, start_time=start_time).values(
  77. 'bucket_id', 'fg', 'sec')
  78. if not vod_hls.exists():
  79. return response.json(173)
  80. source_bucket_id = vod_hls[0]['bucket_id']
  81. fg = vod_hls[0]['fg']
  82. sec = vod_hls[0]['sec']
  83. bucket_qs = VodBucketModel.objects.filter(id=bucket_id).values('bucket')
  84. if not bucket_qs.exists():
  85. return response.json(173)
  86. to_bucket_name = bucket_qs[0]['bucket']
  87. source_bucket_qs = VodBucketModel.objects.filter(id=source_bucket_id).values('bucket', 'region', 'mold')
  88. if not source_bucket_qs.exists():
  89. return response.json(173)
  90. bucket_region = source_bucket_qs[0]['region']
  91. source_bucket_name = source_bucket_qs[0]['bucket']
  92. mold = source_bucket_qs[0]["mold"]
  93. ts_list = []
  94. ts_size = 0
  95. try:
  96. s3_obj = AmazonS3Util(
  97. AWS_ACCESS_KEY_ID[mold],
  98. AWS_SECRET_ACCESS_KEY[mold],
  99. bucket_region
  100. )
  101. for i in range(15):
  102. shift = (i + 1) * 4
  103. duration = (fg >> shift) & 0xf
  104. if duration > 0:
  105. ts_file = '{uid}/vod{channel}/{time}/ts{i}.ts'.format(uid=uid, channel=channel, time=start_time,
  106. i=i)
  107. ts_list.append(ts_file)
  108. ts_size += s3_obj.get_object_size(source_bucket_name, ts_file)
  109. temp_size = ts_size + use_size
  110. if temp_size > all_size:
  111. return response.json(910)
  112. for item in ts_list:
  113. key_name = '{user_id}/ts_file/'.format(user_id=user_id) + item
  114. s3_obj.copy_single_obj(source_bucket_name, item, to_bucket_name, key_name)
  115. IcloudStorageRecord.objects.create(user_id=user_id, uid=uid, channel=channel, time_stamp=start_time,
  116. nickname=nickname,
  117. sec=sec, bucket_id=bucket_id, fg=fg, size=ts_size, store_type=1)
  118. use_details_qs.update(size=temp_size)
  119. return response.json(0)
  120. except Exception as e:
  121. print(e)
  122. return response.json(500)