ServeManagementController.py 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. import hashlib
  4. import json
  5. import time
  6. import urllib
  7. import uuid
  8. import boto3
  9. import threading
  10. import logging
  11. from boto3.session import Session
  12. from django.http import JsonResponse, HttpResponseRedirect, HttpResponse, StreamingHttpResponse
  13. from django.views.generic.base import View
  14. from Model.models import Device_Info, Role, MenuModel, VodBucketModel, CDKcontextModel, Store_Meal, Order_Model
  15. from Object.ResponseObject import ResponseObject
  16. from Object.TokenObject import TokenObject
  17. from Object.UidTokenObject import UidTokenObject
  18. from Service.CommonService import CommonService
  19. from django.db.models import Q, F
  20. from time import strftime
  21. class serveManagement(View):
  22. def get(self, request, *args, **kwargs):
  23. request.encoding = 'utf-8'
  24. operation = kwargs.get('operation')
  25. return self.validation(request.GET, request, operation)
  26. def post(self, request, *args, **kwargs):
  27. request.encoding = 'utf-8'
  28. operation = kwargs.get('operation')
  29. return self.validation(request.POST, request, operation)
  30. def validation(self, request_dict, request, operation):
  31. language = request_dict.get('language', 'en')
  32. response = ResponseObject(language, 'pc')
  33. if operation == '??':
  34. return 0
  35. else:
  36. tko = TokenObject(
  37. request.META.get('HTTP_AUTHORIZATION'),
  38. returntpye='pc')
  39. if tko.code != 0:
  40. return response.json(tko.code)
  41. response.lang = tko.lang
  42. userID = tko.userID
  43. if operation == 'getVodBucketList':
  44. return self.getVodBucketList(userID, request_dict, response)
  45. elif operation == 'addOrEditVodBucket':
  46. return self.addOrEditVodBucket(userID, request_dict, response)
  47. elif operation == 'deleteVodBucket':
  48. return self.deleteVodBucket(userID, request_dict, response)
  49. elif operation == 'getCdkList':
  50. return self.getCdkList(userID, request_dict, response)
  51. elif operation == 'createCdk':
  52. return self.createCdk(request_dict, response)
  53. elif operation == 'deleteCdk':
  54. return self.deleteCdk(request_dict, response)
  55. elif operation == 'downloadCDK':
  56. return self.downloadCDK(request_dict, response)
  57. elif operation == 'getDeviceOrderList':
  58. return self.getDeviceOrderList(request_dict, response)
  59. elif operation == 'deleteDeviceOrder':
  60. return self.deleteDeviceOrder(userID,request_dict, response)
  61. else:
  62. return response.json(404)
  63. def getVodBucketList(self, userID, request_dict, response):
  64. # 查询存储桶数据
  65. print('request_dict: ', request_dict)
  66. bucket = request_dict.get('bucket', None)
  67. mold = request_dict.get('mold', None)
  68. is_free = request_dict.get('is_free', None)
  69. pageNo = request_dict.get('pageNo', None)
  70. pageSize = request_dict.get('pageSize', None)
  71. if not all([pageNo, pageSize]):
  72. return response.json(444)
  73. page = int(pageNo)
  74. line = int(pageSize)
  75. try:
  76. if bucket or mold or is_free: # 条件查询
  77. if bucket:
  78. vod_bucket_qs = VodBucketModel.objects.filter(
  79. bucket=bucket)
  80. elif mold:
  81. vod_bucket_qs = VodBucketModel.objects.filter(
  82. mold=int(mold))
  83. elif is_free:
  84. vod_bucket_qs = VodBucketModel.objects.filter(
  85. is_free=int(is_free))
  86. else: # 查询全部
  87. vod_bucket_qs = VodBucketModel.objects.filter().all()
  88. total = len(vod_bucket_qs)
  89. vod_buckets = vod_bucket_qs[(page - 1) * line:page * line]
  90. vod_bucket_list = []
  91. for vod_bucket in vod_buckets:
  92. vod_bucket_list.append({
  93. 'bucketID': vod_bucket.id,
  94. 'bucket': vod_bucket.bucket,
  95. 'content': vod_bucket.content,
  96. 'mold': vod_bucket.mold,
  97. 'area': vod_bucket.area,
  98. 'region': vod_bucket.region,
  99. 'endpoint': vod_bucket.endpoint,
  100. 'is_free': vod_bucket.is_free,
  101. 'storeDay': vod_bucket.storeDay,
  102. 'region_id': vod_bucket.region_id,
  103. 'addTime': time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(vod_bucket.addTime)),
  104. 'updTime': time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(vod_bucket.updTime)),
  105. })
  106. print('vod_bucket_list: ', vod_bucket_list)
  107. return response.json(
  108. 0, {'list': vod_bucket_list, 'total': total})
  109. except Exception as e:
  110. print(e)
  111. return response.json(500, repr(e))
  112. def addOrEditVodBucket(self, userID, request_dict, response):
  113. # 添加/编辑存储桶
  114. print('request_dict: ', request_dict)
  115. bucketID = request_dict.get('bucketID', None)
  116. bucket = request_dict.get('bucket', '').strip() # 移除字符串头尾的空格
  117. content = request_dict.get('content', '').strip()
  118. mold = int(request_dict.get('mold', 1))
  119. area = request_dict.get('area', '').strip()
  120. region = request_dict.get('region', '').strip()
  121. endpoint = request_dict.get('endpoint', '').strip()
  122. is_free = int(request_dict.get('is_free', 0))
  123. storeDay = int(request_dict.get('storeDay', 0))
  124. region_id = int(request_dict.get('region_id', 1))
  125. isEdit = request_dict.get('isEdit', None)
  126. if not all([bucket, content, area, region, endpoint]):
  127. return response.json(444)
  128. try:
  129. now_time = int(time.time())
  130. vod_bucket_data = {
  131. 'bucket': bucket,
  132. 'content': content,
  133. 'mold': mold,
  134. 'area': area,
  135. 'region': region,
  136. 'endpoint': endpoint,
  137. 'is_free': is_free,
  138. 'storeDay': storeDay,
  139. 'region_id': region_id,
  140. 'addTime': now_time,
  141. 'updTime': now_time,
  142. }
  143. if isEdit:
  144. if not bucketID:
  145. return response.json(444)
  146. VodBucketModel.objects.filter(
  147. id=bucketID).update(
  148. **vod_bucket_data)
  149. else:
  150. VodBucketModel.objects.create(**vod_bucket_data)
  151. return response.json(0)
  152. except Exception as e:
  153. print(e)
  154. return response.json(500, repr(e))
  155. def deleteVodBucket(self, userID, request_dict, response):
  156. # 删除存储桶
  157. print('request_dict: ', request_dict)
  158. bucketID = request_dict.get('bucketID', None)
  159. if not bucketID:
  160. return response.json(444)
  161. try:
  162. VodBucketModel.objects.filter(id=bucketID).delete()
  163. return response.json(0)
  164. except Exception as e:
  165. print(e)
  166. return response.json(500, repr(e))
  167. def getCdkList(self, userID, request_dict, response):
  168. # 获取激活码列表
  169. pageNo = request_dict.get('pageNo', None)
  170. pageSize = request_dict.get('pageSize', None)
  171. cdk = request_dict.get('cdk', None)
  172. order = request_dict.get('order', None)
  173. is_activate = request_dict.get('is_activate', None)
  174. mold = request_dict.get('mold', None)
  175. lang = request_dict.get('lang', 'cn')
  176. if not all([pageNo, pageSize]):
  177. return response.json(444)
  178. page = int(pageNo)
  179. line = int(pageSize)
  180. try:
  181. if cdk:
  182. searchVal = cdk.strip()
  183. if order:
  184. searchVal = order.strip()
  185. if is_activate:
  186. searchVal = is_activate.strip()
  187. cdk_qs = CDKcontextModel.objects.filter().all()
  188. if cdk:
  189. cdk_qs = cdk_qs.filter(cdk__contains=searchVal)
  190. if order:
  191. cdk_qs = cdk_qs.filter(order__contains=searchVal)
  192. if is_activate:
  193. cdk_qs = cdk_qs.filter(is_activate=searchVal)
  194. if mold:
  195. cdk_qs = cdk_qs.filter(rank__bucket__mold=mold)
  196. cdk_qs = cdk_qs.filter(rank__lang__lang=lang)
  197. cdk_qs = cdk_qs.annotate(rank__title=F('rank__lang__title'))
  198. cdk_qs = cdk_qs.values('id', 'cdk', 'create_time', 'valid_time', 'is_activate', 'rank__id', 'rank__title',
  199. 'order',
  200. 'create_time','rank__bucket__mold')
  201. cdk_qs = cdk_qs.order_by('-create_time') # 根据CDK创建时间降序排序
  202. count = cdk_qs.count()
  203. cdk_qs = cdk_qs[(page - 1) * line:page * line]
  204. return response.json(
  205. 0, {'list': list(cdk_qs), 'total': count})
  206. except Exception as e:
  207. print(e)
  208. return response.json(500, repr(e))
  209. def createCdk(self, request_dict, response):
  210. cdk_num = request_dict.get("cdknum", None)
  211. mold = request_dict.get('mold', None)
  212. order = request_dict.get('order', None)
  213. cdk_list = []
  214. sm_qs = Store_Meal.objects.filter(pay_type__payment='cdk_pay',bucket__mold=mold)
  215. if sm_qs.exists:
  216. rank = sm_qs[0].id
  217. for i in range(int(cdk_num)):
  218. nowTime = int(time.time())
  219. cdk = hashlib.md5((str(uuid.uuid1()) + str(nowTime)).encode('utf-8')).hexdigest()
  220. cdk_model = CDKcontextModel(
  221. cdk=cdk,
  222. create_time=nowTime,
  223. valid_time=0,
  224. is_activate=0,
  225. rank_id=rank,
  226. order=order,
  227. )
  228. cdk_list.append(cdk_model)
  229. try:
  230. CDKcontextModel.objects.bulk_create(cdk_list)
  231. except Exception as e:
  232. print(repr(e))
  233. return response.json(404, repr(e))
  234. else:
  235. return response.json(0)
  236. return response.json(0)
  237. def deleteCdk(self, request_dict, response):
  238. cdk_id = request_dict.get("id", None)
  239. try:
  240. CDKcontextModel.objects.get(id=cdk_id).delete()
  241. return response.json(0)
  242. except Exception as e:
  243. return response.json(500, repr(e))
  244. def downloadCDK(self,request_dict, response):
  245. region = request_dict.get('region', None)
  246. content = ''
  247. if region == 'cn':
  248. # 下载国内未使用激活码
  249. content += '激活码(国内)\n'
  250. cdk_inactivate_qs = CDKcontextModel.objects.filter(is_activate=0, rank__bucket__mold=0).values('cdk')
  251. else:
  252. # 下载国外未使用激活码
  253. content += '激活码(国外)\n'
  254. cdk_inactivate_qs = CDKcontextModel.objects.filter(is_activate=0, rank__bucket__mold=1).values('cdk')
  255. for cdk_inactivate in cdk_inactivate_qs:
  256. content += cdk_inactivate['cdk'] + '\n'
  257. # print(content)
  258. response = StreamingHttpResponse(content)
  259. response['Content-Type'] = 'application/octet-stream'
  260. response['Content-Disposition'] = 'attachment;filename="CDK.txt"'
  261. return response
  262. def getDeviceOrderList(self, request_dict, response):
  263. # 获取激活码列表
  264. pageNo = request_dict.get('pageNo', None)
  265. pageSize = request_dict.get('pageSize', None)
  266. uid = request_dict.get('uid', None)
  267. channel = request_dict.get('channel', None)
  268. orderID = request_dict.get('orderID', None)
  269. userID__username = request_dict.get('userID__username', None)
  270. currency = request_dict.get('currency', None)
  271. payType = request_dict.get('payType', None)
  272. status = request_dict.get('status', None)
  273. if not all([pageNo, pageSize]):
  274. return response.json(444)
  275. page = int(pageNo)
  276. line = int(pageSize)
  277. try:
  278. omqs = Order_Model.objects.all()
  279. # 筛选指定设备id的订单
  280. if uid:
  281. omqs = omqs.filter(UID=uid)
  282. if channel:
  283. omqs = omqs.filter(channel=channel)
  284. if orderID:
  285. omqs = omqs.filter(orderID=orderID)
  286. if userID__username:
  287. omqs = omqs.filter(userID__username=userID__username)
  288. if currency:
  289. omqs = omqs.filter(currency=currency)
  290. if payType:
  291. omqs = omqs.filter(payType=payType)
  292. if status:
  293. omqs = omqs.filter(status=status)
  294. if not omqs.exists():
  295. return response.json(0, [])
  296. count = omqs.count()
  297. order_ql = omqs.values("orderID", "UID", "userID__username", "channel",
  298. "desc", "price",
  299. "currency", "addTime", "updTime", "paypal",
  300. "payType",
  301. "rank__day",
  302. "rank__price", "status")
  303. order_ql = order_ql.order_by('-addTime') # 根据CDK创建时间降序排序
  304. order_ql = order_ql[(page - 1) * line:page * line]
  305. return response.json(
  306. 0, {'list': list(order_ql), 'total': count})
  307. except Exception as e:
  308. print(e)
  309. return response.json(500, repr(e))
  310. def deleteDeviceOrder(self,userID,request_dict, response):
  311. orderID = request_dict.get('orderID', None)
  312. if orderID:
  313. Order_Model.objects.filter(orderID=orderID).delete()
  314. return response.json(0)
  315. else:
  316. return response.json(444)