CDKController.py 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. import hashlib
  2. import logging
  3. import time
  4. import uuid
  5. from django.db.models import F
  6. from django.http import StreamingHttpResponse
  7. from django.views.generic.base import View
  8. from Model.models import CDKcontextModel
  9. from Object.ResponseObject import ResponseObject
  10. from Object.TokenObject import TokenObject
  11. class CDKView(View):
  12. def get(self, request, *args, **kwargs):
  13. request.encoding = 'utf-8'
  14. operation = kwargs.get('operation')
  15. return self.validation(request.GET, request, operation)
  16. def post(self, request, *args, **kwargs):
  17. request.encoding = 'utf-8'
  18. operation = kwargs.get('operation')
  19. return self.validation(request.POST, request, operation)
  20. def validation(self, request_dict, request, operation):
  21. response = ResponseObject()
  22. if operation is None:
  23. return response.json(444, 'error path')
  24. else:
  25. token = request_dict.get('token', None)
  26. tko = TokenObject(token)
  27. response.lang = tko.lang
  28. if tko.code != 0:
  29. return response.json(tko.code)
  30. userID = tko.userID
  31. if operation == 'createCDK':
  32. return self.createCDK(request_dict, response)
  33. elif operation == 'deleteCDK':
  34. return self.deleteCDK(request_dict, response)
  35. elif operation == 'queryCDK':
  36. return self.queryCDK(request_dict, response)
  37. elif operation == 'saveOrEditCDK':
  38. return self.saveOrEditCDK(request_dict, response)
  39. elif operation == 'downloadCDK':
  40. return self.downloadCDK(request_dict, response)
  41. def createCDK(self, request_dict, response):
  42. cdk_num = request_dict.get("cdknum", None)
  43. rank = request_dict.get('rank', None)
  44. order = request_dict.get('order', None)
  45. cdk_list = []
  46. for i in range(int(cdk_num)):
  47. nowTime = int(time.time())
  48. cdk = hashlib.md5((str(uuid.uuid1()) + str(nowTime)).encode('utf-8')).hexdigest()
  49. cdk_model = CDKcontextModel(
  50. cdk=cdk,
  51. create_time=nowTime,
  52. valid_time=0,
  53. is_activate=0,
  54. is_down=0,
  55. rank_id=rank,
  56. order=order,
  57. )
  58. cdk_list.append(cdk_model)
  59. try:
  60. CDKcontextModel.objects.bulk_create(cdk_list)
  61. except Exception as e:
  62. print(repr(e))
  63. return response.json(404, repr(e))
  64. else:
  65. return response.json(0)
  66. def queryCDK(self, request_dict, response):
  67. page = int(request_dict.get('page', None))
  68. line = int(request_dict.get('line', None))
  69. # channel = request_dict.get('channel', None)
  70. cdk = request_dict.get('cdk', None)
  71. order = request_dict.get('order', None)
  72. is_activate = request_dict.get('is_activate', None)
  73. lang = request_dict.get('lang', 'cn')
  74. searchVal = ''
  75. if cdk:
  76. searchVal = cdk.strip()
  77. elif order:
  78. searchVal = order.strip()
  79. elif is_activate:
  80. searchVal = is_activate.strip()
  81. logger = logging.getLogger('info')
  82. logger.info('CDK测试打印1: {}'.format(time.localtime(time.time())))
  83. if page and line:
  84. cdk_qs = CDKcontextModel.objects.filter().all()
  85. if searchVal:
  86. if cdk:
  87. cdk_qs = cdk_qs.filter(cdk__contains=searchVal)
  88. elif order:
  89. cdk_qs = cdk_qs.filter(order=searchVal)
  90. elif is_activate:
  91. cdk_qs = cdk_qs.filter(is_activate=searchVal)
  92. cdk_qs = cdk_qs.filter(rank__lang__lang=lang)
  93. cdk_qs = cdk_qs.annotate(rank__title=F('rank__lang__title'))
  94. cdk_qs = cdk_qs.values('id', 'cdk', 'create_time', 'valid_time', 'is_activate', 'rank__id', 'rank__title',
  95. 'rank__bucket__mold', 'order', 'create_time')
  96. cdk_qs = cdk_qs.order_by('-create_time') # 根据CDK创建时间降序排序
  97. count = cdk_qs.count()
  98. cdk_qs = cdk_qs[(page - 1) * line:page * line]
  99. res = {
  100. 'datas': list(cdk_qs),
  101. 'count': count
  102. }
  103. logger.info('CDK测试打印2: {}'.format(time.localtime(time.time())))
  104. return response.json(0, res)
  105. else:
  106. return response.json(444, 'page,line')
  107. def deleteCDK(self, request_dict, response):
  108. cdk_id = request_dict.get("id", None)
  109. lang = request_dict.get("lang", 'cn')
  110. try:
  111. CDKcontextModel.objects.get(cdk=cdk_id).delete()
  112. except Exception as e:
  113. return response.json(500, repr(e))
  114. else:
  115. page = int(request_dict.get('page', None))
  116. line = int(request_dict.get('line', None))
  117. # channel = request_dict.get('channel', None)
  118. cdk = request_dict.get('cdk', None)
  119. order = request_dict.get('order', None)
  120. is_activate = request_dict.get('is_activate', None)
  121. searchVal = ''
  122. if cdk:
  123. searchVal = cdk.strip()
  124. elif order:
  125. searchVal = order.strip()
  126. elif is_activate:
  127. searchVal = is_activate.strip()
  128. if page and line:
  129. cdk_qs = CDKcontextModel.objects.filter().all()
  130. if searchVal:
  131. if cdk:
  132. cdk_qs = cdk_qs.filter(cdk__contains=searchVal)
  133. elif order:
  134. cdk_qs = cdk_qs.filter(order=searchVal)
  135. elif is_activate:
  136. cdk_qs = cdk_qs.filter(is_activate=searchVal)
  137. cdk_qs = cdk_qs.filter(rank__lang__lang=lang)
  138. cdk_qs = cdk_qs.annotate(rank__title=F('rank__lang__title'))
  139. cdk_qs = cdk_qs.values('id', 'cdk', 'create_time', 'valid_time', 'is_activate', 'rank__id',
  140. 'rank__title', 'order',
  141. 'create_time')
  142. cdk_qs = cdk_qs.order_by('-create_time') # 根据CDK创建时间降序排序
  143. count = cdk_qs.count()
  144. cdk_qs = cdk_qs[(page - 1) * line:page * line]
  145. res = {
  146. 'datas': list(cdk_qs),
  147. 'count': count
  148. }
  149. return response.json(0, res)
  150. def saveOrEditCDK(self, request_dict, response):
  151. cdk_id = request_dict.get("id", None)
  152. cdk = request_dict.get('cdk', None)
  153. valid_time = request_dict.get('valid_time', None)
  154. is_activate = request_dict.get('is_activate', None)
  155. rank = request_dict.get('rank', None)
  156. try:
  157. if cdk_id:
  158. if cdk or valid_time or is_activate or rank:
  159. update_dict = {}
  160. if cdk:
  161. update_dict['cdk'] = cdk
  162. if valid_time:
  163. update_dict['valid_time'] = valid_time
  164. if is_activate:
  165. update_dict['is_activate'] = is_activate
  166. if rank:
  167. update_dict['rank'] = rank
  168. CDKcontextModel.objects.filter(id=cdk_id).update(**update_dict)
  169. except Exception as e:
  170. return response.json(500, repr(e))
  171. else:
  172. return response.json(0)
  173. def downloadCDK(self, request_dict, response):
  174. region = request_dict.get('region', None)
  175. content = ''
  176. if region == 'cn':
  177. # 下载国内未使用激活码
  178. content += '激活码(国内)\n'
  179. cdk_inactivate_qs = CDKcontextModel.objects.filter(is_down=0, is_activate=0, rank__bucket__mold=0,
  180. rank__is_show=0).values('cdk')
  181. else:
  182. # 下载国外未使用激活码
  183. content += '激活码(国外)\n'
  184. cdk_inactivate_qs = CDKcontextModel.objects.filter(is_down=0, is_activate=0, rank__bucket__mold=1,
  185. rank__is_show=0).values('cdk')
  186. for cdk_inactivate in cdk_inactivate_qs:
  187. content += cdk_inactivate['cdk'] + '\n'
  188. cdk_inactivate_qs.update(is_down=1)
  189. response = StreamingHttpResponse(content)
  190. response['Content-Type'] = 'application/octet-stream'
  191. response['Content-Disposition'] = 'attachment;filename="CDK.txt"'
  192. return response