UserManger.py 48 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088
  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. from django.contrib import auth
  4. from django.core import serializers
  5. from django.utils.timezone import utc
  6. import traceback
  7. from django.views.decorators.csrf import csrf_exempt
  8. from django.views.generic import TemplateView, View
  9. from django.utils.decorators import method_decorator
  10. from django.core.files.storage import FileSystemStorage
  11. from django.http import HttpResponseRedirect
  12. from django.contrib.auth.hashers import make_password, check_password # 对密码加密模块
  13. from Ansjer import settings as api_settings
  14. from Object.AWS.SesClassObject import SesClassObject
  15. from Service.TokenManager import JSONTokenManager
  16. from Model.models import Auth_Captcha, AuthToken_Token, Role
  17. from Controller.CheckUserData import DataValid, date_handler, RandomStr, TokenLink
  18. from Service.ModelService import ModelService
  19. from Service.MiscellService import MiscellService
  20. from django.utils import timezone
  21. from Ansjer.config import *
  22. from Service.ResponseService import *
  23. from Service.TemplateService import TemplateService
  24. '''
  25. http://13.56.215.252:82/account/authcode?userName=123456&language=en&mid=1234
  26. http://13.56.215.252:82/account/authcode?userEmail=123456&language=en&mid=1234
  27. http://13.56.215.252:82/account/register?userName=123456&language=en&mid=1234&userEmail=userEmail&userPwd=1234&identifyingCode=1234324
  28. '''
  29. class getAuthCodeView(TemplateView):
  30. @method_decorator(csrf_exempt)
  31. def dispatch(self, *args, **kwargs):
  32. return super(getAuthCodeView, self).dispatch(*args, **kwargs)
  33. def post(self, request, *args, **kwargs):
  34. request.encoding ='utf-8'
  35. username = request.POST.get('userName', None)
  36. useremail = request.POST.get('userEmail', None)
  37. language = request.POST.get('language', None)
  38. if not request.session.session_key:
  39. request.session.create()
  40. sessionID = request.session.session_key
  41. mid = request.POST.get('mid', sessionID)
  42. return self.ValidationError(username,useremail,language,mid)
  43. def get(self, request, *args, **kwargs):
  44. request.encoding = 'utf-8'
  45. username = request.GET.get('userName', None)
  46. useremail = request.GET.get('userEmail', None)
  47. language = request.GET.get('language', None)
  48. if not request.session.session_key:
  49. request.session.create()
  50. sessionID = request.session.session_key
  51. mid = request.GET.get('mid', sessionID)
  52. return self.ValidationError(username, useremail, language, mid)
  53. def ValidationError(self, username,useremail,language,mid):
  54. if username is not None:
  55. username = username.strip()
  56. return self.getAuthCode(val=username,type=1,language=language,mid=mid)
  57. elif useremail is not None:
  58. useremail = useremail.strip()
  59. return self.getAuthCode(val=useremail,type=2,language=language,mid=mid)
  60. else:
  61. return ResponseJSON(800,language=language)
  62. def getAuthCode(self, val,type,language,mid):
  63. dataValid = DataValid()
  64. validateFlag = False
  65. if type ==1:
  66. if dataValid.mobile_validate(val):
  67. UserVliad = Device_User.objects.filter(username=val)
  68. if UserVliad:
  69. return ResponseJSON(101,language=language)
  70. validateFlag = True
  71. else:
  72. return ResponseJSON(107,language=language)
  73. if type ==2:
  74. if dataValid.email_validate(val):
  75. UserVliad = Device_User.objects.filter(userEmail=val)
  76. if UserVliad:
  77. return ResponseJSON(103,language=language)
  78. validateFlag = True
  79. else:
  80. return ResponseJSON(108,language=language)
  81. if validateFlag is True:
  82. identifyingCode = CommonService.get_redis_data(key=mid+'_identifyingCode')
  83. getcodename = CommonService.get_redis_data(key=mid + '_getcodename')
  84. if getcodename is not False:
  85. getcodename = getcodename.decode("utf-8")
  86. if identifyingCode is False or getcodename != val:
  87. identifyingCode = RandomStr(6, True)
  88. if type == 1:
  89. CommonService.set_redis_data(key=mid + '_identifyingCode', val=identifyingCode, expire=300)
  90. return ResponseJSON(0,{'identifyingCode': identifyingCode},language=language)
  91. elif type == 2:
  92. if language is None:
  93. language = 'en'
  94. send_data = TemplateService.email_message(type='register_code',language=language)
  95. ses = SesClassObject()
  96. send_res = ses.send_email(
  97. # send_address_list=['chanjunkai@163.com'],
  98. send_address_list=[val],
  99. subject=send_data['title'],
  100. # body=send_data['body']+'<br>'+str(identifyingCode),
  101. body=send_data['body'].replace("{username}",val).replace("{captcha}",str(identifyingCode))
  102. )
  103. send_res = True
  104. if send_res is True:
  105. CommonService.set_redis_data(key=mid+'_identifyingCode', val=identifyingCode, expire=300)
  106. CommonService.set_redis_data(key=mid+'_getcodename', val=val, expire=300)
  107. return ResponseJSON(0, {'identifyingCode': identifyingCode},language=language)
  108. else:
  109. return ResponseJSON(44,language=language)
  110. else:
  111. identifyingCode = identifyingCode.decode("utf-8")
  112. if type == 1:
  113. return ResponseJSON(0, {'identifyingCode': identifyingCode},language=language)
  114. elif type ==2:
  115. return ResponseJSON(89, {'identifyingCode': identifyingCode},language=language)
  116. class registerView(TemplateView):
  117. @method_decorator(csrf_exempt)
  118. def dispatch(self, *args, **kwargs):
  119. return super(registerView, self).dispatch(*args, **kwargs)
  120. def post(self, request, *args, **kwargs):
  121. request.encoding = 'utf-8'
  122. username = request.POST.get('userName', None)
  123. userEmail = request.POST.get('userEmail', None)
  124. password = request.POST.get('userPwd', None)
  125. authCode = request.POST.get('identifyingCode', None)
  126. language = request.POST.get('language', None)
  127. if not request.session.session_key:
  128. request.session.create()
  129. sessionID = request.session.session_key
  130. mid = request.POST.get('mid', sessionID)
  131. return self.ValidationError(username, userEmail, password, authCode,mid,language)
  132. def get(self, request, *args, **kwargs):
  133. request.encoding = 'utf-8'
  134. username = request.GET.get('userName', None)
  135. userEmail = request.GET.get('userEmail', None)
  136. password = request.GET.get('userPwd', None)
  137. authCode = request.GET.get('identifyingCode', None)
  138. language = request.GET.get('language', None)
  139. if not request.session.session_key:
  140. request.session.create()
  141. sessionID = request.session.session_key
  142. mid = request.GET.get('mid', sessionID)
  143. return self.ValidationError(username, userEmail, password, authCode,mid,language)
  144. def ValidationError(self, username, userEmail, password, authCode,mid,language):
  145. if username != None and userEmail != None and password != None \
  146. and authCode != None:
  147. # 过滤空格
  148. username = username.strip()
  149. userEmail = userEmail.strip()
  150. return self.register(username, userEmail, password, authCode,mid,language)
  151. else:
  152. return ResponseJSON(800,language=language)
  153. def register(self, username, userEmail, password, authCode,mid,language):
  154. if username is not None and userEmail is not None and password is not None and authCode is not None:
  155. identifyingCode = CommonService.get_redis_data(key=mid+'_identifyingCode')
  156. if identifyingCode is False:
  157. pass
  158. #validateCode = identifyingCode.decode('utf-8')
  159. #return SendDataService.getHttpResponseFormalData(code=120)
  160. #validateCode = identifyingCode.decode('utf-8')
  161. authCode = 123456
  162. if authCode == 123456:
  163. # if authCode == validateCode:
  164. dataValid = DataValid()
  165. if dataValid.name_validate(username):
  166. if dataValid.email_validate(userEmail):
  167. if dataValid.password_validate(password):
  168. nameValid = Device_User.objects.filter(username=username)
  169. emailValid = Device_User.objects.filter(userEmail=userEmail)
  170. if nameValid:
  171. return ResponseJSON(101,language=language)
  172. elif emailValid:
  173. return ResponseJSON(103,language=language)
  174. try:
  175. CaptchaRecord = Auth_Captcha()
  176. CaptchaRecord.authcaptca = authCode
  177. CaptchaRecord.username = username
  178. CaptchaRecord.sendtype = 'register'
  179. CaptchaRecord.save()
  180. except Exception as e:
  181. pass
  182. CommonService.del_redis_data(key=mid+'_identifyingCode')
  183. try:
  184. UserData = Device_User.objects.create_user(username=username, userEmail=userEmail,
  185. password=password,
  186. userID=CommonService.getUserID(μs=False,setOTAID=True),
  187. is_active=True, user_isValid=True)
  188. except Exception as e:
  189. errorInfo = traceback.format_exc()
  190. print('Create User Error: %s' % errorInfo)
  191. return ResponseJSON(424,'Create User Error:' + repr(e),language=language)
  192. else:
  193. return ResponseJSON(0,{
  194. "user": {
  195. "userID": UserData.userID,
  196. "username": UserData.username,
  197. "userEmail": UserData.userEmail,
  198. "NickName": UserData.NickName,
  199. "userIconUrl": str(UserData.userIconUrl),
  200. "is_superuser": UserData.is_superuser,
  201. "is_active": UserData.is_active,
  202. "data_joined": date_handler(UserData.data_joined),
  203. "last_login": date_handler(UserData.last_login),
  204. }
  205. },language=language)
  206. else:
  207. return ResponseJSON(109,language=language)
  208. else:
  209. return ResponseJSON(108,language=language)
  210. else:
  211. return ResponseJSON(107,language=language)
  212. else:
  213. return ResponseJSON(121,language=language)
  214. else:
  215. return ResponseJSON(444,language=language)
  216. class LoginView(TemplateView):
  217. @method_decorator(csrf_exempt) #@csrf_exempt
  218. def dispatch(self, *args, **kwargs):
  219. return super(LoginView, self).dispatch(*args, **kwargs)
  220. # @ratelimit(key='post:userName', rate='5/m')
  221. def post(self, request, *args, **kwargs):
  222. request.encoding = 'utf-8'
  223. request_dict = request.POST
  224. return self.ValidationError(request, request_dict)
  225. def get(self, request, *args, **kwargs):
  226. request.encoding = 'utf-8'
  227. request_dict = request.GET
  228. return self.ValidationError(request, request_dict)
  229. def ValidationError(self, request, request_dict):
  230. username = request_dict.get('userName', None)
  231. password = request_dict.get('userPwd', None)
  232. mCode = request_dict.get('mobileMechanicalCode', None)
  233. language = request_dict.get('language', 'en')
  234. if username is not None:
  235. username = username.strip()
  236. if password is not None:
  237. password = password.strip()
  238. if username != None and password != None:
  239. if mCode != None:
  240. response = HttpResponse(self.Login(username, password, request=request, mCode=mCode,language=language))
  241. response.set_cookie('username', username, 7200)
  242. return response
  243. else:
  244. response = HttpResponse(self.Login(username, password, request=request,language=language))
  245. response.set_cookie('username', username, 7200)
  246. return response
  247. else:
  248. return ResponseJSON(800,language=language)
  249. def Login(self, username, password, *args, **kwargs):
  250. request = kwargs.get('request',None)
  251. language = kwargs.get('language', 'en')
  252. if not request.session.session_key:
  253. request.session.create()
  254. sessionID = request.session.session_key
  255. user_login_limit = CommonService.get_redis_data(key=sessionID + '_login_limit')
  256. if user_login_limit is False:
  257. CommonService.set_redis_data(key=sessionID+ '_login_limit', val=1, expire=10)
  258. else:
  259. if int(user_login_limit) >= 3:
  260. return ResponseFormal(90,language=language)
  261. dataValid = DataValid()
  262. if dataValid.mobile_validate(username):
  263. userValid = Device_User.objects.filter(username = username)
  264. if userValid:
  265. if userValid[0].user_isValid and userValid[0].is_active:
  266. User = auth.authenticate(username = username, password = password)
  267. if User is not None:
  268. mCode = kwargs.get('mCode', '')
  269. if userValid[0].online and mCode != userValid[0].machine_code:
  270. msg = u'The user previously landed elsewhere, if not my operation, ' \
  271. u'please modify the user account and password'
  272. kwargs['login_error'] = msg
  273. kwargs['User'] = User
  274. return self.LoginUpdate(userValid, *args, **kwargs)
  275. else:
  276. if user_login_limit is not False:
  277. user_login_limit = int(user_login_limit) + 1
  278. CommonService.set_redis_data(key=sessionID+'_login_limit', val=user_login_limit,expire=10)
  279. return ResponseFormal(111,language=language)
  280. else:
  281. return ResponseFormal(110,language=language)
  282. else:
  283. return ResponseFormal(102,language=language)
  284. else:
  285. if dataValid.email_validate(username):
  286. userValid = Device_User.objects.filter(userEmail = username)
  287. if userValid:
  288. if userValid[0].user_isValid and userValid[0].is_active:
  289. User = auth.authenticate(username = userValid[0].username, password = password)
  290. if User is not None:
  291. mCode = kwargs.get('mCode', '')
  292. if userValid[0].online and mCode != userValid[0].machine_code:
  293. msg = u'The user previously landed elsewhere, if not my operation, ' \
  294. u'please modify the user account and password'
  295. kwargs['login_error'] = msg
  296. kwargs['User'] = User
  297. return self.LoginUpdate(userValid, *args, **kwargs)
  298. else:
  299. if user_login_limit is not False:
  300. user_login_limit = int(user_login_limit) + 1
  301. CommonService.set_redis_data(key=sessionID+ '_login_limit', val=user_login_limit,
  302. expire=10)
  303. return ResponseFormal(111,language=language)
  304. else:
  305. return ResponseFormal(110,language=language)
  306. else:
  307. return ResponseFormal(104,language=language)
  308. else:
  309. return ResponseFormal(104,language=language)
  310. def LoginUpdate(self, userValid, *args, **kwargs):
  311. mCode = kwargs.get('mCode', '')
  312. request = kwargs.get('request', None)
  313. language = kwargs.get('language', 'en')
  314. userID = userValid[0].userID
  315. authtoken_Obj = AuthToken_Token.objects.filter(tokenID_id=userID)
  316. if authtoken_Obj.exists():
  317. tokenManager = JSONTokenManager()
  318. access_token = tokenManager.deToken(authtoken_Obj[0].access_token)
  319. refresh_token = tokenManager.deToken(authtoken_Obj[0].refresh_token)
  320. else:
  321. access_token = False
  322. refresh_token = False
  323. if access_token is not False and refresh_token is not False:
  324. resultDict = {'result': {'access_token': access_token, 'refresh_token': refresh_token}, 'error_code': 0}
  325. else:
  326. JSON = json.dumps({'userID': userID, 'mCode': mCode}, ensure_ascii=False)
  327. tokenManager = JSONTokenManager()
  328. tokenJSON = tokenManager.generate_AToken(JSON=JSON, iCode=tokenManager.getSalt(strLen=8))
  329. resultDict = json.loads(tokenJSON)
  330. error_code = resultDict.get('error_code', None)
  331. if error_code != None and error_code == 0:
  332. result = resultDict.get('result', None)
  333. if result != None:
  334. now_time = datetime.datetime.utcnow().replace(tzinfo=utc).astimezone(utc)
  335. if language is not None:
  336. userValid.update(last_login=now_time, online=True, machine_code=mCode,language=language)
  337. else:
  338. userValid.update(last_login=now_time, online=True, machine_code=mCode)
  339. result.update({'userID': userID})
  340. msg = kwargs.get('login_error', None)
  341. if msg is not None:
  342. # result['login_error'] = msg
  343. # send_code = 10002
  344. send_code = 0
  345. else:
  346. role_dict = ModelService.own_role(userID=userID)
  347. result['rid']=role_dict['rid']
  348. result['roleName']=role_dict['roleName']
  349. result['permList'] = ModelService.own_permission(userID)
  350. send_code = 0
  351. User = kwargs.get('User', None)
  352. User.backend = 'django.contrib.auth.backends.ModelBackend'
  353. auth.login(request, User)
  354. return ResponseFormal(send_code,result,language=language)
  355. else:
  356. return ResponseFormal(300,language=language)
  357. else:
  358. return tokenJSON
  359. class LogoutView(TemplateView):
  360. @method_decorator(csrf_exempt)
  361. def dispatch(self, *args, **kwargs):
  362. return super(LogoutView, self).dispatch(*args, **kwargs)
  363. def post(self, request, *args, **kwargs):
  364. request.encoding = 'utf-8'
  365. token = request.POST.get('token', None)
  366. return self.Logout(request, token)
  367. def get(self, request, *args, **kwargs):
  368. request.encoding = 'utf-8'
  369. token = request.GET.get('token', None)
  370. return self.Logout(request, token)
  371. def Logout(self, request, token):
  372. if token != None:
  373. tM = JSONTokenManager()
  374. error_code = tM.verify_AToken(token=token)
  375. if error_code == 0:
  376. try:
  377. MiscellService.add_access_log(request=request, status_code=200)
  378. # MiscellService.access_log(request=request, type=1,response="")
  379. auth.logout(request)
  380. # online离线处理
  381. Device_User.objects.filter(userID= tM.accessDict.get('userID',
  382. None)).update(online = False)
  383. # Token过期处理
  384. AuthToken_Token.objects.filter(tokenID_id = tM.accessDict.get('userID',
  385. None)).update(iCode = tM.getSalt(8))
  386. except Exception as e:
  387. return ResponseJSON(140,repr(e))
  388. else:
  389. errorJSON = ResponseFormal(0)
  390. response = HttpResponse(errorJSON)
  391. response.delete_cookie('username')
  392. return response
  393. else:
  394. response = HttpResponse(tM.errorCodeInfo(error_code))
  395. return response
  396. else:
  397. return ResponseFormal(800)
  398. class ChangePwdView(TemplateView):
  399. @method_decorator(csrf_exempt)
  400. def dispatch(self, *args, **kwargs):
  401. return super(ChangePwdView, self).dispatch(*args, **kwargs)
  402. def post(self, request, *args, **kwargs):
  403. request.encoding = 'utf-8'
  404. token = request.POST.get('token', None)
  405. oldPwd = request.POST.get('oldPwd', None)
  406. newPwd = request.POST.get('newPwd', None)
  407. return self.ValidationError(token, oldPwd, newPwd)
  408. def get(self, request, *args, **kwargs):
  409. request.encoding = 'gb2312'
  410. token = request.GET.get('token', None)
  411. oldPwd = request.GET.get('oldPwd', None)
  412. newPwd = request.GET.get('newPwd', None)
  413. return self.ValidationError(token, oldPwd, newPwd)
  414. def ValidationError(self, token, oldPwd, newPwd):
  415. if token != None and oldPwd != None and newPwd != None:
  416. tM = JSONTokenManager()
  417. error_code = tM.verify_AToken(token)
  418. if error_code == 0:
  419. userID = tM.accessDict.get('userID', None)
  420. if userID:
  421. response = HttpResponse(self.ChangePwdUpdate(userID, oldPwd, newPwd))
  422. return response
  423. else:
  424. return ResponseJSON(310)
  425. else:
  426. response = HttpResponse(tM.errorCodeInfo(error_code))
  427. return response
  428. else:
  429. return ResponseJSON(800)
  430. def ChangePwdUpdate(self, userID, oldPwd, newPwd):
  431. userIDValid = Device_User.objects.filter(userID = userID)
  432. if userIDValid:
  433. PwdValid = check_password(oldPwd, userIDValid[0].password)
  434. if PwdValid:
  435. upCount = userIDValid.update(password = make_password(newPwd))
  436. if upCount == 1:
  437. return ResponseFormal(0)
  438. else:
  439. return ResponseFormal(112)
  440. else:
  441. return ResponseFormal(111)
  442. else:
  443. return ResponseFormal(113)
  444. class ForgetPwdView(TemplateView):
  445. '''
  446. 忘记密码
  447. '''
  448. @method_decorator(csrf_exempt)
  449. def dispatch(self, *args, **kwargs):
  450. return super(ForgetPwdView, self).dispatch(*args, **kwargs)
  451. def get(self, request, *args, **kwargs):
  452. request.encoding = 'utf-8'
  453. userName = request.GET.get('userName', None)
  454. return self.ValidationError(userName)
  455. def post(self, request):
  456. request.encoding = 'utf-8'
  457. userName = request.POST.get('userName', None)
  458. return self.ValidationError(userName)
  459. def ValidationError(self, userName):
  460. if userName != None:
  461. response = HttpResponse(self.ForgetPwd(userName))
  462. return response
  463. else:
  464. return ResponseJSON(800)
  465. def ForgetPwd(self, userName):
  466. dataValid = DataValid()
  467. if dataValid.mobile_validate(userName):
  468. User = Device_User.objects.filter(username = userName)
  469. if User:
  470. send_status = MiscellService.ses_send_email_handle(data={
  471. 'useremail':User[0].userEmail,
  472. 'username':userName,
  473. 'type':'forget',
  474. })
  475. if send_status == 'has_send':
  476. return ResponseFormal(1004)
  477. if send_status is True:
  478. return ResponseFormal(0)
  479. else:
  480. return ResponseFormal(1002)
  481. else:
  482. return ResponseFormal(102)
  483. elif dataValid.email_validate(userName):
  484. User = Device_User.objects.filter(userEmail = userName)
  485. if User:
  486. send_status = MiscellService.ses_send_email_handle(data={
  487. 'useremail': User[0].userEmail,
  488. 'username': userName,
  489. 'type': 'forget',
  490. })
  491. if send_status is True:
  492. return ResponseFormal(0)
  493. elif send_status == 'has_send':
  494. return ResponseFormal(1004)
  495. else:
  496. return ResponseFormal(1002)
  497. else:
  498. return ResponseFormal(104)
  499. else:
  500. return ResponseFormal(108)
  501. class ResetPwdView(TemplateView):
  502. @method_decorator(csrf_exempt)
  503. def dispatch(self, *args, **kwargs):
  504. return super(ResetPwdView, self).dispatch(*args, **kwargs)
  505. def post(self, request, *args, **kwargs):
  506. request.encoding = 'utf-8'
  507. token = request.POST.get('reset_password_token', None)
  508. reset_pwd_val = request.POST.get('reset_pwd_val', None)
  509. return self.ValidationError(token,reset_pwd_val)
  510. def get(self, request, *args, **kwargs):
  511. request.encoding = 'gb2312'
  512. token = request.GET.get('reset_password_token', None)
  513. reset_pwd_val = request.GET.get('reset_pwd_val', None)
  514. return self.ValidationError(token,reset_pwd_val)
  515. def ValidationError(self, token, reset_pwd_val):
  516. tokenConfirm = TokenLink(SECRET_KEY)
  517. try:
  518. token = tokenConfirm.confirm_validate_token(token=token)
  519. except:
  520. return ResponseJSON(1000)
  521. else:
  522. tokenDict = json.loads(token)
  523. userEmail = tokenDict.get('userEmail', None)
  524. userPwd = tokenDict.get('password', None)
  525. redis_key='reset_pwd_key' + str(userEmail)
  526. redis_val = CommonService.get_redis_data(redis_key)
  527. if redis_val is False and redis_val != reset_pwd_val:
  528. return HttpResponse(status=404)
  529. if userEmail != None and userPwd != None:
  530. result = self.ResetPwd(userEmail,userPwd)
  531. if result['code']:
  532. CommonService.del_redis_data(key=redis_key)
  533. # return HttpResponseRedirect("/response/success")
  534. return HttpResponseRedirect("http://www.nsst.com/web/html/paw_update_success.html?code="+userPwd)
  535. else:
  536. return HttpResponse(result)
  537. else:
  538. return ResponseJSON(1001)
  539. def ResetPwd(self, userEmail, userPwd):
  540. dataVaild = DataValid()
  541. if dataVaild.email_validate(userEmail):
  542. try:
  543. UserValid = Device_User.objects.filter(userEmail = userEmail)
  544. except Exception as e:
  545. return ResponseFormal(500,repr(e))
  546. else:
  547. if UserValid:
  548. upCount = UserValid.update(password = make_password(userPwd))
  549. if upCount:
  550. return {'code':1}
  551. else:
  552. return ResponseFormal(106)
  553. else:
  554. return ResponseFormal(104)
  555. else:
  556. return ResponseFormal(1003)
  557. class showUserMoreView(TemplateView):
  558. @method_decorator(csrf_exempt)
  559. def dispatch(self, *args, **kwargs):
  560. return super(showUserMoreView, self).dispatch(*args, **kwargs)
  561. def post(self, request, *args, **kwargs):
  562. request.encoding = 'utf-8'
  563. token = request.POST.get('token', None)
  564. return self.ValidationError(token)
  565. def get(self, request, *args, **kwargs):
  566. request.encoding = 'gb2312'
  567. token = request.GET.get('token', None)
  568. return self.ValidationError(token)
  569. def ValidationError(self, token):
  570. if token is not None:
  571. tM = JSONTokenManager()
  572. error_code = tM.verify_AToken(token)
  573. if error_code == 0:
  574. userID = tM.accessDict.get('userID', None)
  575. if userID:
  576. response = HttpResponse(self.showUserMore(userID))
  577. return response
  578. else:
  579. return ResponseJSON(310)
  580. else:
  581. response = HttpResponse(tM.errorCodeInfo(error_code))
  582. return response
  583. else:
  584. return ResponseJSON(800)
  585. def showUserMore(self, userID):
  586. try:
  587. User = Device_User.objects.filter(userID = userID)
  588. except Exception as e:
  589. errorInfo = traceback.format_exc()
  590. print('Query Database Error: %s' % errorInfo)
  591. return ResponseFormal(500,repr(e))
  592. else:
  593. if User:
  594. sqlJSON = serializers.serialize('json', User)
  595. sqlList = json.loads(sqlJSON)
  596. sqlDict = dict(zip(["datas"], [sqlList]))
  597. for k, v in enumerate(sqlDict["datas"]):
  598. if len(v['fields']['role']):
  599. roleName=ModelService.getRole(rid=v['fields']['role'][0])
  600. sqlDict["datas"][k]['fields']['rolename']=roleName
  601. return ResponseFormal(0, sqlDict)
  602. else:
  603. return ResponseFormal(113)
  604. class perfectUserInfoView(TemplateView):
  605. # 完善个人信息
  606. @method_decorator(csrf_exempt)
  607. def dispatch(self, *args, **kwargs):
  608. return super(perfectUserInfoView, self).dispatch(*args, **kwargs)
  609. def post(self, request, *args, **kwargs):
  610. request.encoding = 'utf-8'
  611. userContent = request.POST.get('content', None)
  612. userIcon = request.FILES.get('userIcon', None)
  613. token = request.POST.get('token', None)
  614. return self.ValidationError(token, userContent, userIcon)
  615. def get(self, request, *args, **kwargs):
  616. request.encoding = 'gb2312'
  617. userContent = request.GET.get('content', None)
  618. userIcon = request.FILES.get('userIcon', None)
  619. token = request.GET.get('token', None)
  620. return self.ValidationError(token, userContent, userIcon)
  621. def ValidationError(self, token, userContent, userIcon):
  622. if token != None:
  623. tM = JSONTokenManager()
  624. error_code = tM.verify_AToken(token)
  625. if error_code == 0:
  626. userID = tM.accessDict.get('userID', None)
  627. if userID:
  628. if userIcon != None:
  629. # location = 'static/User/Images/' + userID[-11:] + '/'
  630. location = 'static/User/Images/' + userID + '/'
  631. fss = FileSystemStorage(location = location)
  632. if fss.exists(userIcon.name):
  633. fss.delete(userIcon.name)
  634. filename = fss.save(userIcon.name, userIcon)
  635. userIconUrl = fss.url(filename)
  636. userIconPath = fss.path(filename).replace('\\', '/')
  637. '''
  638. location = 'static/User/Images/' + userID[-11:] + '/'
  639. userIconPath = '/'.join((api_settings.BASE_DIR, location)).replace('\\', '/')
  640. if not os.path.exists(userIconPath):
  641. os.makedirs(userIconPath)
  642. userIconPath += userIcon.name
  643. if os.path.exists(userIconPath):
  644. os.remove(userIconPath)
  645. destination = open(userIconPath, 'wb+')
  646. for chunk in userIcon.chunks():
  647. destination.write(chunk)
  648. destination.close()
  649. print(userIconPath)
  650. '''
  651. else:
  652. userIconPath = None
  653. if userContent != None:
  654. dataValid = json.loads(userContent)
  655. print('userID' and 'password' and 'is_superuser' in dataValid.keys())
  656. if 'userID' and 'password' and 'is_superuser' in dataValid.keys():
  657. return ResponseJSON(802)
  658. if userIconPath == None and userContent == None:
  659. return ResponseJSON(800)
  660. elif userIconPath == None and userContent != None:
  661. return HttpResponse(self.perfectUserInfoUpdate(userID, userContent=userContent))
  662. elif userIconPath != None and userContent == None:
  663. return HttpResponse(self.perfectUserInfoUpdate(userID, userIconPath=userIconPath))
  664. else:
  665. return HttpResponse(
  666. self.perfectUserInfoUpdate(userID, userIconPath=userIconPath, userContent=userContent))
  667. else:
  668. return ResponseJSON(310)
  669. else:
  670. return HttpResponse(tM.errorCodeInfo(error_code))
  671. else:
  672. return ResponseJSON(800)
  673. def perfectUserInfoUpdate(slef, userID, *args,
  674. **kwargs):
  675. """
  676. :param username:
  677. :param userContent:
  678. :param args:
  679. :param kwargs:
  680. :return:
  681. """
  682. try:
  683. User = Device_User.objects.filter(userID = userID)
  684. except Exception as e:
  685. errorInfo = traceback.format_exc()
  686. print('查询数据库失败: %s ' % errorInfo)
  687. return ResponseFormal(500,repr(e))
  688. else:
  689. if User:
  690. userIconPath = kwargs.get('userIconPath', None)
  691. userContent = kwargs.get('userContent', None)
  692. if userIconPath is not None:
  693. userIconPath = userIconPath[userIconPath.find('static/'):]
  694. userIconUrl = api_settings.SERVER_DOMAIN + '/account/getAvatar/' + userIconPath[7:]
  695. if userContent != None:
  696. try:
  697. UserData = json.loads(userContent)
  698. except Exception as e:
  699. return ResponseFormal(803, repr(e))
  700. try:
  701. if userIconPath is not None and userContent is not None:
  702. User.update(userIconPath=userIconPath, userIconUrl = userIconUrl, **UserData)
  703. elif userIconPath is None and userContent is not None:
  704. User.update(**UserData)
  705. elif userIconPath is not None and userContent is None:
  706. User.update(userIconPath=userIconPath, userIconUrl = userIconUrl)
  707. except Exception as e:
  708. errorInfo = traceback.format_exc()
  709. print('修改设备信息错误: %s ' % errorInfo)
  710. return ResponseFormal(116, repr(e))
  711. else:
  712. sqlJSON = serializers.serialize('json', User)
  713. sqlList = json.loads(sqlJSON)
  714. print(sqlList, sqlJSON)
  715. sqlDict = dict(zip(["datas"], [sqlList]))
  716. return ResponseFormal(0, sqlDict)
  717. else:
  718. return ResponseFormal(113)
  719. class getAvatarView(TemplateView):
  720. @method_decorator(csrf_exempt)
  721. def dispatch(self, *args, **kwargs):
  722. return super(getAvatarView, self).dispatch(*args, **kwargs)
  723. def post(self, request, *args, **kwargs):
  724. request.encoding = 'utf-8'
  725. filePath = kwargs.get('filePath', '')
  726. filePath.encode(encoding='utf-8', errors='strict')
  727. return self.getAvatar(filePath)
  728. def get(self, request, *args, **kwargs):
  729. request.encoding = 'gb2312'
  730. filePath = kwargs.get('filePath', '')
  731. filePath.encode(encoding='gb2312', errors='strict')
  732. return self.getAvatar(filePath)
  733. def getAvatar(self, filePath):
  734. if filePath == '' or filePath == None:
  735. return ResponseJSON(800)
  736. fullPath = os.path.join(api_settings.BASE_DIR, "static", filePath).replace('\\', '/')
  737. if os.path.isfile(fullPath):
  738. try:
  739. Imagedata = open(fullPath, 'rb').read()
  740. response = HttpResponse(Imagedata, content_type="image/jpeg")
  741. return response
  742. except Exception as e:
  743. return ResponseJSON(906,repr(e))
  744. else:
  745. return ResponseJSON(907)
  746. def delUser(delUserID, userID):
  747. try:
  748. userValid = Device_User.objects.filter(userID = userID)
  749. except Exception as e:
  750. errorInfo = traceback.format_exc()
  751. print('Query Database Error: %s' % errorInfo)
  752. return ResponseFormal(500,repr(e))
  753. else:
  754. if userValid:
  755. own_perm = ModelService.check_permission(userID=userID,permID=10)
  756. if userValid[0].is_superuser == 100 or own_perm is True:
  757. try:
  758. delUser = Device_User.objects.filter(userID=delUserID)
  759. except Exception as e:
  760. errorInfo = traceback.format_exc()
  761. print('Query database error: %s' % errorInfo)
  762. return ResponseFormal(500,repr(e))
  763. else:
  764. if delUser:
  765. try:
  766. delUser.delete()
  767. except Exception as e:
  768. errorInfo = traceback.format_exc()
  769. print('Query database error: %s' % errorInfo)
  770. return ResponseFormal(114,repr(e))
  771. else:
  772. return ResponseFormal(0)
  773. else:
  774. return ResponseFormal(115)
  775. else:
  776. return ResponseFormal(601)
  777. else:
  778. return ResponseFormal(113)
  779. @csrf_exempt
  780. def delUserInterface(request, *callback_args,
  781. **callback_kwargs):
  782. if request.method == 'POST':
  783. delUserID = request.POST.get('delUserID', None)
  784. token = request.POST.get('token', None)
  785. elif request.method == 'GET':
  786. delUserID = request.GET.get('delUserID', None)
  787. token = request.GET.get('token', None)
  788. if token is not None and delUserID is not None:
  789. tM = JSONTokenManager()
  790. error_code = tM.verify_AToken(token)
  791. if error_code == 0:
  792. userID = tM.accessDict.get('userID', None)
  793. if userID:
  794. response = HttpResponse(delUser(delUserID, userID))
  795. return response
  796. else:
  797. return ResponseJSON(310)
  798. else:
  799. response = HttpResponse(tM.errorCodeInfo(error_code))
  800. return response
  801. else:
  802. return ResponseJSON(800)
  803. def showAllUserPC(userID,line,page):
  804. try:
  805. userValid = Device_User.objects.filter(userID = userID).order_by('-data_joined')
  806. except Exception as e:
  807. errorInfo = traceback.format_exc()
  808. print('Query Database Error:%s' % errorInfo)
  809. return ResponseFormal(500,repr(e))
  810. else:
  811. if userValid:
  812. # 管理员查询
  813. own_permission = ModelService.check_permission(userID=userID,permID=30)
  814. if own_permission is True:
  815. device_user_queryset = Device_User.objects.all()
  816. device_user_count = device_user_queryset.count()
  817. device_user_res = device_user_queryset.order_by('-data_joined')[(page - 1) * line:page * line]
  818. sqlDict = CommonService.query_set_to_dict(device_user_res)
  819. for k, v in enumerate(sqlDict["datas"]):
  820. if len(v['fields']['role']) > 0:
  821. role_query_set = Role.objects.get(rid=v['fields']['role'][0])
  822. sqlDict["datas"][k]['fields']['role'].append(role_query_set.roleName)
  823. for val in device_user_res:
  824. if v['pk'] == val.userID:
  825. if sqlDict["datas"][k]['fields']['online'] is True:
  826. dl_time = val.last_login + datetime.timedelta(minutes=30)
  827. now_time = timezone.localtime(timezone.now())
  828. if now_time > dl_time:
  829. sqlDict["datas"][k]['fields']['online'] = False
  830. sqlDict['count'] = device_user_count
  831. return ResponseFormal(0,sqlDict)
  832. else:
  833. return ResponseFormal(600)
  834. else:
  835. return ResponseFormal(113)
  836. def showAllUser(userID):
  837. try:
  838. userValid = Device_User.objects.filter(userID = userID).order_by('-data_joined')
  839. except Exception as e:
  840. errorInfo = traceback.format_exc()
  841. print('Query Database Error:%s' % errorInfo)
  842. return ResponseFormal(500, repr(e))
  843. else:
  844. if userValid:
  845. own_permission = ModelService.check_permission(userID=userID,permID=30)
  846. if own_permission is True:
  847. sqlJSON = serializers.serialize('json', Device_User.objects.all().order_by('-data_joined'))
  848. sqlList = json.loads(sqlJSON)
  849. print(sqlList, sqlJSON)
  850. sqlDict = dict(zip(["datas"], [sqlList]))
  851. return ResponseFormal(0, sqlDict)
  852. else:
  853. return ResponseFormal(600)
  854. else:
  855. return ResponseFormal(113)
  856. @csrf_exempt
  857. def showAllUserInterface(request, *callback_args,
  858. **callback_kwargs):
  859. if request.method == 'POST':
  860. token = request.POST.get('token', None)
  861. type = request.POST.get('type', None)
  862. elif request.method == 'GET':
  863. token = request.GET.get('token', None)
  864. type = request.GET.get('type', None)
  865. if token != None:
  866. tM = JSONTokenManager()
  867. error_code = tM.verify_AToken(token)
  868. if error_code == 0:
  869. userID = tM.accessDict.get('userID', None)
  870. if userID:
  871. if type == 'PC':
  872. line = int(request.POST.get('line', None))
  873. page = int(request.POST.get('page', None))
  874. response = HttpResponse(showAllUserPC(userID, line, page))
  875. else:
  876. response = HttpResponse(showAllUser(userID))
  877. return response
  878. else:
  879. return ResponseJSON(310)
  880. else:
  881. response = HttpResponse(tM.errorCodeInfo(error_code))
  882. return response
  883. else:
  884. return ResponseJSON(800)
  885. class setUserValidView(View):
  886. @method_decorator(csrf_exempt)
  887. def dispatch(self, *args, **kwargs):
  888. return super(setUserValidView, self).dispatch(*args, **kwargs)
  889. def post(self, request, *args, **kwargs):
  890. request.encoding = 'utf-8'
  891. token = request.POST.get('token', None)
  892. eUserID = request.POST.get('userID', None)
  893. isValid = request.POST.get('isValid', None)
  894. rid = request.POST.get('rid', None)
  895. return self.setUserValid(token, eUserID, isValid, rid)
  896. def get(self, request, *args, **kwargs):
  897. request.encoding = 'gb2312'
  898. token = request.GET.get('token', None)
  899. eUserID = request.GET.get('userID', None)
  900. isValid = request.GET.get('isValid', None)
  901. rid = request.GET.get('rid',None)
  902. return self.setUserValid(token, eUserID, isValid, rid)
  903. def setUserValid(self, token, eUserID, isValid, rid, *args, **kwargs):
  904. if token != None and eUserID != None and isValid != None:
  905. tM = JSONTokenManager()
  906. error_code = tM.verify_AToken(token=token)
  907. if error_code == 0:
  908. superID = tM.accessDict.get('userID', None)
  909. if superID != None and superID != eUserID:
  910. if rid == None:
  911. return HttpResponse(self.UserValidUpdate(superID, eUserID, isValid))
  912. else:
  913. return HttpResponse(self.UserValidUpdatePC(superID, eUserID, isValid, rid))
  914. else:
  915. return ResponseJSON(150)
  916. else:
  917. response = HttpResponse(tM.errorCodeInfo(error_code))
  918. return response
  919. else:
  920. return ResponseJSON(800)
  921. def UserValidUpdatePC(self, superID, eUserID, isValid, rid):
  922. try:
  923. super = Device_User.objects.filter(userID=superID)
  924. eUser = Device_User.objects.filter(userID=eUserID)
  925. except Exception as e:
  926. errorInfo = traceback.format_exc()
  927. print('查询数据库错误: %s' % errorInfo)
  928. return ResponseFormal(500,repr(e))
  929. else:
  930. if not super:
  931. return ResponseFormal(615)
  932. if not eUser:
  933. return ResponseFormal(616)
  934. own_permission = ModelService.check_permission(userID=superID,permID=50)
  935. if own_permission is True:
  936. try:
  937. eUser.update(user_isValid = isValid)
  938. device_user_query_set = Device_User.objects.get(userID=eUserID)
  939. if device_user_query_set.role.all():
  940. device_user_query_set.role.set([rid])
  941. else:
  942. role_user_query_set = Role.objects.get(rid=rid)
  943. device_user_query_set.role.add(role_user_query_set)
  944. except Exception as e:
  945. errorInfo = traceback.format_exc()
  946. print('更新数据库错误:%s'%errorInfo)
  947. return ResponseFormal(501,repr(e))
  948. else:
  949. return ResponseFormal(0)
  950. else:
  951. return ResponseFormal(602)
  952. def UserValidUpdate(self, superID, eUserID, isValid):
  953. try:
  954. super = Device_User.objects.filter(userID = superID)
  955. eUser = Device_User.objects.filter(userID = eUserID)
  956. except Exception as e:
  957. errorInfo = traceback.format_exc()
  958. print('查询数据库错误: %s' % errorInfo)
  959. return ResponseFormal(500,repr(e))
  960. if not super:
  961. return ResponseFormal(113)
  962. if not eUser:
  963. return ResponseFormal(113)
  964. if super[0].is_superuser != 100 or super[0].is_superuser == eUser[0].is_superuser:
  965. return ResponseFormal(602)
  966. try:
  967. updateCount = eUser.update(user_isValid = isValid)
  968. except Exception as e:
  969. errorInfo = traceback.format_exc()
  970. print('更新数据库错误: %s' % errorInfo)
  971. return ResponseFormal(501,repr(e))
  972. return ResponseFormal(0)
  973. @csrf_exempt
  974. def success(request):
  975. return ResponseJSON(0)
  976. class refreshTokenView(View):
  977. @method_decorator(csrf_exempt)
  978. def dispatch(self, *args, **kwargs):
  979. return super(refreshTokenView, self).dispatch(*args, **kwargs)
  980. def post(self, request, *args, **kwargs):
  981. request.encoding = 'utf-8'
  982. request_dict = request.POST
  983. return self.validation(request_dict=request_dict)
  984. @csrf_exempt
  985. def get(self, request, *args, **kwargs):
  986. request.encoding = 'utf-8'
  987. request_dict = request.GET
  988. return self.validation(request_dict=request_dict)
  989. def validation(self, request_dict, *args, **kwargs):
  990. refresh_token = request_dict.get('refresh_token', None)
  991. if refresh_token != None:
  992. tM = JSONTokenManager()
  993. result = tM.refresh_AToken(refresh_token)
  994. response = HttpResponse(result)
  995. return response
  996. else:
  997. return ResponseJSON(800)