SuperPasswordTool.py 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. # -*- encoding: utf-8 -*-
  2. """
  3. @File : UserDeviceShareController.py
  4. @Time : 2023/2/3 13:25
  5. @Author : guanhailong
  6. @Email : guanhailong@asj6.wecom.work
  7. @Software: PyCharm
  8. """
  9. import datetime
  10. import time
  11. from django.db import transaction
  12. from Controller.CheckUserData import RandomStr
  13. from Model.models import Device_User, DeviceSuperPassword, SysMsgModel
  14. from Object.RedisObject import RedisObject
  15. from Object.ResponseObject import ResponseObject
  16. from Object.TokenObject import TokenObject
  17. from django.views import View
  18. from Service.CommonService import CommonService
  19. class SuperPasswordView(View):
  20. def get(self, request, *args, **kwargs):
  21. request.encoding = 'utf-8'
  22. operation = kwargs.get('operation')
  23. request_dict = request.GET
  24. return self.validation(request_dict, request, operation)
  25. def post(self, request, *args, **kwargs):
  26. request.encoding = 'utf-8'
  27. operation = kwargs.get('operation')
  28. request_dict = request.GET
  29. return self.validation(request_dict, request, operation)
  30. def validation(self, request_dict, request, operation):
  31. tko = TokenObject(
  32. request.META.get('HTTP_AUTHORIZATION'))
  33. lang = request_dict.get('lang', tko.lang)
  34. response = ResponseObject(lang)
  35. if tko.code != 0:
  36. return response.json(tko.code)
  37. userID = tko.userID
  38. if operation == 'getAuthorizationCode': # 用户提交请求
  39. return self.getAuthorizationCode(request_dict, response, userID)
  40. if operation == 'customerServiceManagement': # 审核用户请求/生成超级密码
  41. return self.customerServiceManagement(request_dict, response)
  42. if operation == 'getDeviceSuperPassword': # 查询用户请求表
  43. return self.getDeviceSuperPassword(request_dict, response)
  44. if operation == 'verifyTheVerificationCode': # 检验验证码
  45. return self.verifyTheVerificationCode(request_dict, response, userID)
  46. if operation == 'deleteInformation': # 删除信息
  47. return self.deleteInformation(request_dict, response)
  48. else:
  49. return response.json(404)
  50. def getAuthorizationCode(self, request_dict, response, userID):
  51. """
  52. 用户提交请求
  53. @param uid:设备id
  54. @param request_dict:请求参数
  55. @param response:响应对象
  56. @param describe:需求描述
  57. @param Purchase_channel:购买渠道描述
  58. @param orderID:订单id
  59. @param buyTime:购买时间
  60. @return:
  61. """
  62. uid = request_dict.get('uid', None)
  63. describe = request_dict.get('describe', None)
  64. if not all([uid, describe]):
  65. return response.json(444)
  66. purchase_channel = request_dict.get('purchase_channel', None)
  67. orderID = request_dict.get('orderID', None)
  68. buyTime = request_dict.get('buyTime', None)
  69. lang = request_dict.get('lang', 'en')
  70. try:
  71. now = int(time.time())
  72. addTime = now
  73. device_user_qs = Device_User.objects.filter(userID=userID)
  74. if not device_user_qs.exists():
  75. return response.json(173)
  76. if buyTime:
  77. buyTime = datetime.datetime.strptime(buyTime, '%Y-%m-%d')
  78. buyTime = CommonService.str_to_timestamp(str_time=str(buyTime))
  79. DeviceSuperPassword.objects.create(uid=uid, orderID=orderID, describe=describe,
  80. purchase_channel=purchase_channel, addTime=addTime, userID_id=userID,
  81. buyTime=buyTime, status=0, lang=lang)
  82. return response.json(0)
  83. except Exception as e:
  84. print('生成验证码异常,errLine:{}, errMsg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  85. return response.json(500, repr(e))
  86. def customerServiceManagement(self, request_dict, response):
  87. """
  88. 审核用户请求/生成超级密码
  89. @param request_dict:请求参数
  90. @param response:响应对象
  91. @param hint:提示内容
  92. @return:
  93. """
  94. ID = request_dict.get('ID', None)
  95. userID = request_dict.get('userID', None)
  96. uid = request_dict.get('uid', None)
  97. status = request_dict.get('status', None)
  98. hint = request_dict.get('hint', None)
  99. lang = request_dict.get('lang', 'en')
  100. if not all({ID, uid, userID}):
  101. return response.json(444)
  102. now = int(time.time())
  103. try:
  104. with transaction.atomic():
  105. device_super_password_qs = DeviceSuperPassword.objects.filter(id=ID, uid=uid, userID=userID)
  106. if not device_super_password_qs.exists():
  107. return response.json(173)
  108. status = int(status)
  109. if status == 1:
  110. # 验证码生成
  111. super_code = RandomStr(6, True)
  112. super_password_id = "super_password_%s" % userID
  113. redisObj = RedisObject()
  114. redis = redisObj.set_data(key=super_password_id, val=super_code, expire=86400)
  115. if redis is False:
  116. return response.json(121)
  117. device_super_password_qs.update(status=status)
  118. if lang == 'en':
  119. msg = "Your authorization code is " + super_code + ",valid within 24 hours"
  120. else:
  121. msg = "您的授权代码:" + super_code + ",24小时内有效"
  122. SysMsgModel.objects.create(userID_id=userID, msg=msg, addTime=now, updTime=now, uid=uid,
  123. eventType=2)
  124. return response.json(0)
  125. if status == 0 and len(hint) > 1:
  126. device_super_password_qs.update(status=status, hint=hint)
  127. msg = hint
  128. SysMsgModel.objects.create(userID_id=userID, msg=msg, addTime=now, updTime=now, uid=uid,
  129. eventType=2)
  130. return response.json(0)
  131. return response.json(177)
  132. except Exception as e:
  133. print('修改状态异常,errLine:{}, errMsg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  134. return response.json(500, repr(e))
  135. def getDeviceSuperPassword(self, request_dict, response):
  136. """
  137. 查询用户请求表
  138. @param request_dict:请求参数
  139. @param response:响应对象
  140. @return:
  141. """
  142. pageNo = request_dict.get('pageNo', None)
  143. pageSize = request_dict.get('pageSize', None)
  144. status = request_dict.get('status', None)
  145. userID = request_dict.get('userID', None)
  146. uid = request_dict.get('uid', None)
  147. if not all([pageNo, pageSize]):
  148. return response.json(444)
  149. page = int(pageNo)
  150. line = int(pageSize)
  151. try:
  152. device_super_password_qs = DeviceSuperPassword.objects.all()
  153. if status:
  154. device_super_password_qs = device_super_password_qs.filter(status=status)
  155. if userID:
  156. device_super_password_qs = device_super_password_qs.filter(userID=userID)
  157. if uid:
  158. device_super_password_qs = device_super_password_qs.filter(uid=uid)
  159. if not device_super_password_qs.exists():
  160. return response.json(0, [])
  161. count = device_super_password_qs.count()
  162. device_super_password_qs = device_super_password_qs.values('id',
  163. 'uid',
  164. 'userID',
  165. 'orderID',
  166. 'describe',
  167. 'purchase_channel',
  168. 'addTime',
  169. 'status',
  170. 'buyTime',
  171. 'hint',
  172. 'lang')
  173. device_super_password_qs = device_super_password_qs.order_by('-addTime')[
  174. (page - 1) * line:page * line]
  175. return response.json(0, {'list': list(device_super_password_qs), 'count': count})
  176. except Exception as e:
  177. print('查询异常,errLine:{}, errMsg:{}'.format(e.__traceback__.tb_lineno, repr(e)))
  178. return response.json(500, repr(e))
  179. def verifyTheVerificationCode(self, request_dict, response, userID):
  180. """
  181. 检验验证码
  182. @param request_dict:请求参数
  183. @param response:响应对象
  184. @param userID:用户ID
  185. @param authcode:验证码
  186. @return:
  187. """
  188. authcode = request_dict.get('authcode', None)
  189. if authcode:
  190. authcode = CommonService.decode_data(authcode)
  191. if not len(authcode) == 6:
  192. return response.json(121)
  193. super_password_id = 'super_password_' + userID
  194. redisObj = RedisObject()
  195. # redis里面的验证码
  196. redis_image_code = redisObj.get_data(key=super_password_id)
  197. # 验证用户输入的验证码和redis中的验证码
  198. if redis_image_code is False or authcode.lower() != redis_image_code.lower():
  199. return response.json(121)
  200. else:
  201. return response.json(0)
  202. else:
  203. return response.json(444)
  204. def deleteInformation(self, request_dict, response):
  205. """
  206. 删除信息
  207. @param request_dict:请求参数
  208. @param response:响应对象
  209. @param id:主键
  210. """
  211. id = request_dict.get('id', None)
  212. if not id:
  213. return response.json(444)
  214. device_super_password_qs = DeviceSuperPassword.objects.filter(id=id)
  215. if not device_super_password_qs.exists():
  216. return response.json(173)
  217. device_super_password_qs.delete()
  218. return response.json(0)