VodBucket.py 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. """
  4. @Copyright (C) ansjer cop Video Technology Co.,Ltd.All rights reserved.
  5. @AUTHOR: ASJRD018
  6. @NAME: AnsjerFormal
  7. @software: PyCharm
  8. @DATE: 2018/12/15 15:30
  9. @Version: python3.6
  10. @MODIFY DECORD:ansjer dev
  11. @file: VodBucket.py
  12. @Contact: chanjunkai@163.com
  13. """
  14. import json
  15. import math
  16. from django.utils.decorators import method_decorator
  17. from django.views.decorators.csrf import csrf_exempt
  18. from django.views.generic.base import View
  19. from Model.models import VodBucketModel, UID_Bucket, Store_Meal, Device_Info, OssCrdModel, VodHlsModel, StsCrdModel, \
  20. Unused_Uid_Meal
  21. from Object.ResponseObject import ResponseObject
  22. from Object.TokenObject import TokenObject
  23. from Service.ModelService import ModelService
  24. from django.db import transaction
  25. import time
  26. from Service.VodHlsService import SplitVodHlsObject
  27. class VodBucketView(View):
  28. @method_decorator(csrf_exempt)
  29. def dispatch(self, *args, **kwargs):
  30. return super(VodBucketView, self).dispatch(*args, **kwargs)
  31. def get(self, request, *args, **kwargs):
  32. request.encoding = 'utf-8'
  33. operation = kwargs.get('operation')
  34. return self.validation(request.GET, operation)
  35. def post(self, request, *args, **kwargs):
  36. request.encoding = 'utf-8'
  37. operation = kwargs.get('operation')
  38. request_dict = json.loads(request.body.decode('utf-8'))
  39. return self.validation(request_dict, operation)
  40. def validation(self, request_dict, operation):
  41. response = ResponseObject()
  42. if operation is None:
  43. return response.json(444, 'error path')
  44. token = request_dict.get('token', None)
  45. # 设备主键uid
  46. tko = TokenObject(token)
  47. response.lang = tko.lang
  48. if tko.code != 0:
  49. return response.json(tko.code)
  50. userID = tko.userID
  51. if operation == 'add':
  52. return self.do_add(request_dict, response, userID)
  53. elif operation == 'delete':
  54. return self.do_delete(request_dict, response, userID)
  55. elif operation == 'update':
  56. return self.do_update(request_dict, response, userID)
  57. elif operation == 'query':
  58. return self.do_query(response, userID)
  59. else:
  60. return response.json(414)
  61. def do_add(self, request_dict, response, userID):
  62. own_perm = ModelService.check_perm(userID, 40)
  63. if not own_perm:
  64. return response.json(404)
  65. request_dict.pop('token')
  66. nowTime = int(time.time())
  67. try:
  68. VodBucketModel.objects.create(addTime=nowTime, updTime=nowTime, **request_dict)
  69. except Exception as e:
  70. return response.json(10, repr(e))
  71. res = list(VodBucketModel.objects.values())
  72. return response.json(0, res)
  73. def do_query(self, response, userID):
  74. own_perm = ModelService.check_perm(userID, 30)
  75. if not own_perm:
  76. return response.json(404)
  77. res = list(VodBucketModel.objects.values())
  78. return response.json(0, res)
  79. def do_update(self, request_dict, response, userID):
  80. own_perm = ModelService.check_perm(userID, 50)
  81. if not own_perm:
  82. return response.json(404)
  83. request_dict.pop('token')
  84. nowTime = int(time.time())
  85. id = request_dict.get('id', None)
  86. try:
  87. VodBucketModel.objects.filter(id=id).update(updTime=nowTime, **request_dict)
  88. except Exception as e:
  89. return response.json(10, repr(e))
  90. # res = list(VodBucketModel.objects.values())
  91. return response.json(0, {'updTime': nowTime})
  92. def do_delete(self, request, response, userID):
  93. own_perm = ModelService.check_perm(userID, 10)
  94. if not own_perm:
  95. return response.json(404)
  96. id = request.get('id', None)
  97. try:
  98. VodBucketModel.objects.filter(id=id).delete()
  99. except Exception as e:
  100. return response.json(10, repr(e))
  101. res = list(VodBucketModel.objects.values())
  102. return response.json(0, res)
  103. class UidBucketView(View):
  104. @method_decorator(csrf_exempt)
  105. def dispatch(self, *args, **kwargs):
  106. return super(UidBucketView, self).dispatch(*args, **kwargs)
  107. def get(self, request, *args, **kwargs):
  108. request.encoding = 'utf-8'
  109. operation = kwargs.get('operation')
  110. return self.validation(request.GET, operation)
  111. def post(self, request, *args, **kwargs):
  112. request.encoding = 'utf-8'
  113. operation = kwargs.get('operation')
  114. # request_dict = json.loads(request.body.decode('utf-8'))
  115. return self.validation(request.POST, operation)
  116. def validation(self, request_dict, operation):
  117. response = ResponseObject()
  118. if operation is None:
  119. return response.json(444, 'error path')
  120. token = request_dict.get('token', None)
  121. # 设备主键uid
  122. tko = TokenObject(token)
  123. response.lang = tko.lang
  124. if tko.code != 0:
  125. return response.json(tko.code)
  126. userID = tko.userID
  127. if operation == 'add':
  128. return self.do_add(request_dict, response, userID)
  129. elif operation == 'delete':
  130. return self.do_delete(request_dict, response, userID)
  131. elif operation == 'update':
  132. return self.do_update(request_dict, response,userID)
  133. elif operation == 'query':
  134. return self.do_query(request_dict, response,userID)
  135. else:
  136. return response.json(414)
  137. def do_add(self, request_dict, response, userID):
  138. own_perm = ModelService.check_perm(userID, 40)
  139. if not own_perm:
  140. return response.json(404)
  141. rank = request_dict.get('rank', None)
  142. uid = request_dict.get('uid', None)
  143. channel = request_dict.get('channel', None)
  144. if not rank:
  145. return response.json(444, 'rank')
  146. dvqs = Device_Info.objects.filter(UID=uid)
  147. if not dvqs.exists():
  148. return response.json(10, '设备不存在')
  149. try:
  150. smqs = Store_Meal.objects.filter(id=rank).values("bucket__storeDay", "day", "bucket_id")
  151. if not smqs.exists():
  152. return response.json(10, '套餐信息不存在')
  153. bucketId = smqs[0]['bucket_id']
  154. addDay = smqs[0]['day']
  155. addTime = addDay * 3600 * 24
  156. nowTime = int(time.time())
  157. ubqs = UID_Bucket.objects.filter(uid=uid, channel=channel).values("bucket_id", "endTime",
  158. "bucket__storeDay")
  159. if ubqs.exists():
  160. if nowTime > ubqs[0]['endTime']:
  161. endTime = nowTime + addTime
  162. ubqs.update(endTime=nowTime + addTime)
  163. else:
  164. # 同一个bucket续费
  165. if bucketId == ubqs[0]['bucket_id']:
  166. endTime = ubqs[0]['endTime'] + addTime
  167. ubqs.update(endTime=endTime)
  168. else:
  169. if ubqs[0]['bucket__storeDay'] > smqs[0]['bucket__storeDay']:
  170. return response.json(10, '不可降级')
  171. else:
  172. origin_storeDay = int(ubqs[0]['bucket__storeDay'])
  173. upgrade_storeDay = int(smqs[0]['bucket__storeDay'])
  174. ctcTime = ubqs[0]['endTime'] - nowTime
  175. multiple = math.ceil(upgrade_storeDay / origin_storeDay)
  176. ubqs.update(endTime=ctcTime / multiple + addTime + ubqs[0]['endTime'])
  177. else:
  178. endTime = nowTime + addTime
  179. UID_Bucket.objects.create(uid=uid, channel=channel, bucket_id=bucketId, endTime=endTime)
  180. except Exception as e:
  181. return response.json(10, repr(e))
  182. else:
  183. return response.json(0, {'endTime': endTime})
  184. def do_query(self, request_dict, response, userID):
  185. own_perm = ModelService.check_perm(userID, 30)
  186. if not own_perm:
  187. return response.json(404)
  188. page = int(request_dict.get('page', None))
  189. line = int(request_dict.get('line', None))
  190. uid = request_dict.get('uid', None)
  191. ubqs = UID_Bucket.objects
  192. if uid:
  193. ubqs = ubqs.filter(uid=uid)
  194. ubqs = ubqs.values('id', 'uid', 'channel', 'status', 'endTime', 'bucket__bucket',
  195. 'bucket__storeDay', 'bucket__area')
  196. res = {
  197. 'datas': list(ubqs[(page - 1) * line:page * line]),
  198. 'count': ubqs.count()
  199. }
  200. return response.json(0, res)
  201. def do_update(self, request_dict, response, userID):
  202. own_perm = ModelService.check_perm(userID, 50)
  203. if not own_perm:
  204. return response.json(404)
  205. status = request_dict.get('status', None)
  206. id = request_dict.get('id', None)
  207. ubqs = UID_Bucket.objects.filter(id=id).values('endTime')
  208. nowTime = int(time.time())
  209. endTime = ubqs[0]['endTime']
  210. if not ubqs.exists():
  211. return response.json(10, '未购买')
  212. if endTime > nowTime:
  213. ubqs.update(status=status)
  214. return response.json(0)
  215. else:
  216. return response.json(10, '过期了')
  217. def do_delete(self, request_dict, response, userID):
  218. own_perm = ModelService.check_perm(userID, 10)
  219. if not own_perm:
  220. return response.json(404)
  221. try:
  222. id = request_dict.get('id', None)
  223. page = int(request_dict.get('page', None))
  224. line = int(request_dict.get('line', None))
  225. uid_bucket_qs = UID_Bucket.objects.filter(id=id)
  226. uid = uid_bucket_qs[0].uid
  227. bucket_id = uid_bucket_qs[0].bucket_id
  228. # channel = uid_bucket_qs[0].channel
  229. with transaction.atomic():
  230. uid_bucket_qs.delete()
  231. # OssCrdModel.objects.filter(uid=uid, channel=channel).delete()
  232. VodHlsModel.objects.filter(uid=uid).delete()
  233. # 删除vod_hls分表数据
  234. split_vod_hls_obj = SplitVodHlsObject()
  235. split_vod_hls_obj.del_vod_hls_data(uid=uid)
  236. StsCrdModel.objects.filter(uid=uid).delete()
  237. Unused_Uid_Meal.objects.filter(uid=uid).delete()
  238. except Exception as e:
  239. return response.json(10, repr(e))
  240. else:
  241. ubqs = UID_Bucket.objects.values('id', 'uid', 'channel', 'status', 'endTime', 'bucket__bucket',
  242. 'bucket__storeDay', 'bucket__area')
  243. res = {
  244. 'datas': list(ubqs[(page - 1) * line:page * line]),
  245. 'count': ubqs.count()
  246. }
  247. return response.json(0, res)