User.py 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253
  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: langer
  7. @software: PyCharm
  8. @DATE: 2019/6/3 17:29
  9. @Version: python3.6
  10. @MODIFY DECORD:ansjer dev
  11. @file: User.py
  12. @Contact: chanjunkai@163.com
  13. """
  14. import json
  15. from django.http import HttpResponse
  16. from django.views.generic import TemplateView
  17. from django.views.decorators.csrf import csrf_exempt
  18. from django.utils.decorators import method_decorator
  19. from object.ResponseObject import ResponseObject
  20. from django.contrib.auth.hashers import make_password, check_password
  21. from model.models import UserModel, LangSetModel, LangAreaModel, LangPermModel, ProjectPermModel, LangProjectModel
  22. import time
  23. from object.TokenObject import TokenObject
  24. class registerView(TemplateView):
  25. def post(self, request, *args, **kwargs):
  26. request.encoding = 'utf-8'
  27. request_dict = json.loads(request.body.decode('utf-8'))
  28. return self.validate(request_dict)
  29. def get(self, request, *args, **kwargs):
  30. request.encoding = 'utf-8'
  31. request_dict = request.GET
  32. return self.validate(request_dict)
  33. def validate(self, request_dict):
  34. response = ResponseObject()
  35. username = request_dict.get('username', None)
  36. password = request_dict.get('password', None)
  37. role_id = request_dict.get('role_id', None)
  38. if username and password:
  39. nowTime = int(time.time())
  40. create_dict = {
  41. 'username': username,
  42. 'password': make_password(password),
  43. 'role_id': role_id,
  44. 'addTime': nowTime,
  45. 'updTime': nowTime}
  46. try:
  47. UserModel.objects.create(**create_dict)
  48. except Exception as e:
  49. return response.json(0, repr(e))
  50. else:
  51. return response.json(0)
  52. else:
  53. return response.json(444)
  54. class loginView(TemplateView):
  55. def post(self, request, *args, **kwargs):
  56. request.encoding = 'utf-8'
  57. request_dict = json.loads(request.body.decode('utf-8'))
  58. return self.validate(request_dict)
  59. def get(self, request, *args, **kwargs):
  60. request.encoding = 'utf-8'
  61. request_dict = request.GET
  62. return self.validate(request_dict)
  63. def validate(self, request_dict):
  64. response = ResponseObject()
  65. username = request_dict.get('username', None)
  66. password = request_dict.get('password', None)
  67. if username and password:
  68. user_qs = UserModel.objects.filter(username=username)
  69. pp_qs = ProjectPermModel.objects.filter(user__id=user_qs[0].id).values('project__id')
  70. pp_data = []
  71. for pp in pp_qs:
  72. pp_data.append(pp['project__id'])
  73. print('login')
  74. if not user_qs.exists():
  75. return response.json(401)
  76. if check_password(password, user_qs[0].password):
  77. tko = TokenObject()
  78. res = tko.generate({'userID': user_qs[0].id})
  79. res['role_id'] = user_qs[0].role_id
  80. res['role_type'] = user_qs[0].role_type
  81. res['project_perm'] = pp_data
  82. print(res)
  83. return response.json(0, res)
  84. else:
  85. return response.json(401)
  86. else:
  87. return response.json(444)
  88. class queryView(TemplateView):
  89. def post(self, request, *args, **kwargs):
  90. request.encoding = 'utf-8'
  91. request_dict = json.loads(request.body.decode('utf-8'))
  92. return self.validate(request_dict)
  93. def get(self, request, *args, **kwargs):
  94. request.encoding = 'utf-8'
  95. request_dict = request.GET
  96. return self.validate(request_dict)
  97. def validate(self, request_dict):
  98. response = ResponseObject()
  99. token = request_dict.get('token', None)
  100. tko = TokenObject(token)
  101. if tko.code == 0:
  102. userID = tko.userID
  103. user_qs = UserModel.objects.filter(id=userID, username='admin')
  104. if not user_qs.exists():
  105. return response.json(403)
  106. um_qs = UserModel.objects.filter().values('id', 'username', 'role_id')
  107. ls_qs = LangSetModel.objects.filter().values('user__id', 'lang__lang')
  108. lp_qs = LangPermModel.objects.filter().values('user__id', 'lang__lang')
  109. pp_qs = ProjectPermModel.objects.filter().values('user__id', 'project__name')
  110. res = []
  111. for um in um_qs:
  112. for ls in ls_qs:
  113. if um['id'] == ls['user__id']:
  114. if 'lang_arr' not in um:
  115. um['lang_arr'] = []
  116. um['lang_arr'].append(ls['lang__lang'])
  117. for lp in lp_qs:
  118. if um['id'] == lp['user__id']:
  119. if 'lp_arr' not in um:
  120. um['lp_arr'] = []
  121. um['lp_arr'].append(lp['lang__lang'])
  122. for pp in pp_qs:
  123. if um['id'] == pp['user__id']:
  124. if 'pp_arr' not in um:
  125. um['pp_arr'] = []
  126. um['pp_arr'].append(pp['project__name'])
  127. res.append(um)
  128. return response.json(0, res)
  129. else:
  130. return response.json(tko.code)
  131. class updateView(TemplateView):
  132. def post(self, request, *args, **kwargs):
  133. request.encoding = 'utf-8'
  134. request_dict = json.loads(request.body.decode('utf-8'))
  135. return self.validate(request_dict)
  136. def get(self, request, *args, **kwargs):
  137. request.encoding = 'utf-8'
  138. request_dict = request.GET
  139. return self.validate(request_dict)
  140. def validate(self, request_dict):
  141. response = ResponseObject()
  142. token = request_dict.get('token', None)
  143. id = request_dict.get('id', None)
  144. langSetArr = request_dict.get('langSetArr', None)
  145. langPermArr = request_dict.get('langPermArr', None)
  146. username = request_dict.get('username', None)
  147. role_id = request_dict.get('role_id', None)
  148. projectPermArr = request_dict.get('projectPermArr', None)
  149. nowTime = int(time.time())
  150. tko = TokenObject(token)
  151. if tko.code == 0:
  152. user = UserModel.objects.get(id=id)
  153. user.username = username
  154. user.role_id = role_id
  155. user.updTime = nowTime
  156. user.save()
  157. if id and langSetArr:
  158. LangSetModel.objects.filter(user__id=id).delete()
  159. LangPermModel.objects.filter(user__id=id).delete()
  160. ProjectPermModel.objects.filter(user__id=id).delete()
  161. for ls in langSetArr:
  162. LangSetModel.objects.create(lang=LangAreaModel.objects.get(id=ls),
  163. user=UserModel.objects.get(id=id), addTime=nowTime, updTime=nowTime)
  164. for lp in langPermArr:
  165. LangPermModel.objects.create(lang=LangAreaModel.objects.get(id=lp),
  166. user=UserModel.objects.get(id=id), addTime=nowTime, updTime=nowTime)
  167. for pp in projectPermArr:
  168. ProjectPermModel.objects.create(project=LangProjectModel.objects.get(id=pp),
  169. user=UserModel.objects.get(id=id))
  170. return response.json(0)
  171. else:
  172. return response.json(0)
  173. else:
  174. return response.json(tko.code)
  175. class deleteView(TemplateView):
  176. def post(self, request, *args, **kwargs):
  177. request.encoding = 'utf-8'
  178. request_dict = json.loads(request.body.decode('utf-8'))
  179. return self.validate(request_dict)
  180. def get(self, request, *args, **kwargs):
  181. request.encoding = 'utf-8'
  182. request_dict = request.GET
  183. return self.validate(request_dict)
  184. def validate(self, request_dict):
  185. response = ResponseObject()
  186. token = request_dict.get('token', None)
  187. tko = TokenObject(token)
  188. if tko.code == 0:
  189. id = request_dict.get('id', None)
  190. if id:
  191. UserModel.objects.filter(id=id).delete()
  192. return response.json(0)
  193. else:
  194. return response.json(0)
  195. else:
  196. return response.json(tko.code)
  197. class initView(TemplateView):
  198. def post(self, request, *args, **kwargs):
  199. request.encoding = 'utf-8'
  200. request_dict = json.loads(request.body.decode('utf-8'))
  201. return self.validate(request_dict)
  202. def get(self, request, *args, **kwargs):
  203. request.encoding = 'utf-8'
  204. request_dict = request.GET
  205. return self.validate(request_dict)
  206. def validate(self, request_dict):
  207. response = ResponseObject()
  208. token = request_dict.get('token', None)
  209. tko = TokenObject(token)
  210. if tko.code == 0:
  211. userID = tko.userID
  212. user_qs = UserModel.objects.filter(id=userID, username='admin')
  213. if user_qs.exists():
  214. is_admin = 1
  215. else:
  216. is_admin = 0
  217. lang_perm_ql = LangPermModel.objects.filter(user__id=userID).values_list('lang__lang', flat=True)
  218. lang_perm_ls = list(lang_perm_ql)
  219. res = {
  220. 'user_perm':is_admin,
  221. 'lang_perm_ls': lang_perm_ls
  222. }
  223. return response.json(0, res)
  224. else:
  225. return response.json(tko.code)