views.py 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # **************************************************************************
  4. # Copyright © 2016 jianglin
  5. # File Name: views.py
  6. # Author: jianglin
  7. # Email: xiyang0807@gmail.com
  8. # Created: 2016-10-28 10:26:10 (CST)
  9. # Last Update:星期日 2017-4-2 11:49:2 (CST)
  10. # By:
  11. # Description:
  12. # **************************************************************************
  13. from random import sample
  14. from string import ascii_letters, digits
  15. from flask import current_app, redirect, render_template, request, url_for
  16. from flask.views import MethodView
  17. from flask_babelex import gettext as _
  18. from flask_login import current_user, login_required, login_user, logout_user
  19. from flask_principal import Identity, identity_changed, AnonymousIdentity
  20. from flask_maple.auth.forms import (ForgetForm, LoginForm, RegisterForm,
  21. form_validate)
  22. from forums.api.user.models import User
  23. from forums.common.response import HTTPResponse
  24. from forums.common.serializer import Serializer
  25. from forums.permission import is_guest
  26. class LoginView(MethodView):
  27. @is_guest
  28. def get(self):
  29. form = LoginForm()
  30. data = {'form': form}
  31. return render_template('auth/login.html', **data)
  32. @form_validate(LoginForm)
  33. def post(self):
  34. form = LoginForm()
  35. post_data = form.data
  36. username = post_data.pop('username', None)
  37. password = post_data.pop('password', None)
  38. remember = post_data.pop('remember', None)
  39. remember = True if remember else None
  40. user = User.query.filter_by(username=username).first()
  41. if user and user.check_password(password):
  42. login_user(user, remember=remember)
  43. identity_changed.send(
  44. current_app._get_current_object(), identity=Identity(user.id))
  45. serializer = Serializer(user, many=False, depth=1)
  46. return HTTPResponse(
  47. HTTPResponse.NORMAL_STATUS, data=serializer.data).to_response()
  48. return HTTPResponse(
  49. HTTPResponse.AUTH_USER_OR_PASSWORD_ERROR).to_response()
  50. class LogoutView(MethodView):
  51. @login_required
  52. def get(self):
  53. logout_user()
  54. identity_changed.send(
  55. current_app._get_current_object(), identity=AnonymousIdentity())
  56. return redirect(request.args.get('next') or '/')
  57. class RegisterView(MethodView):
  58. @is_guest
  59. def get(self):
  60. form = RegisterForm()
  61. data = {'form': form}
  62. return render_template('auth/register.html', **data)
  63. @form_validate(RegisterForm)
  64. def post(self):
  65. form = RegisterForm()
  66. post_data = form.data
  67. username = post_data.pop('username', None)
  68. email = post_data.pop('email', None)
  69. password = post_data.pop('password', None)
  70. user = User.query.filter_by(username=username).first()
  71. if user is not None:
  72. return HTTPResponse(HTTPResponse.AUTH_USERNAME_UNIQUE).to_response(
  73. )
  74. user = User.query.filter_by(email=email).first()
  75. if user is not None:
  76. return HTTPResponse(HTTPResponse.AUTH_EMAIL_UNIQUE).to_response()
  77. user = User(username=username, email=email)
  78. user.set_password(password)
  79. user.save()
  80. login_user(user)
  81. self.email(user)
  82. return HTTPResponse(HTTPResponse.NORMAL_STATUS).to_response()
  83. def email(self, user):
  84. token = user.email_token
  85. confirm_url = url_for(
  86. 'auth.confirm_token', token=token, _external=True)
  87. html = render_template('templet/email.html', confirm_url=confirm_url)
  88. subject = _("Please confirm your email!")
  89. user.send_email(subject=subject, html=html)
  90. class ForgetView(MethodView):
  91. @is_guest
  92. def get(self):
  93. form = ForgetForm()
  94. data = {'form': form}
  95. return render_template('auth/forget.html', **data)
  96. @form_validate(ForgetForm)
  97. def post(self):
  98. form = ForgetForm()
  99. post_data = form.data
  100. email = post_data.pop('email', None)
  101. user = User.query.filter_by(email=email).first()
  102. if not user:
  103. return HTTPResponse(
  104. HTTPResponse.AUTH_EMAIL_NOT_REGISTER).to_response()
  105. password = ''.join(sample(ascii_letters + digits, 12))
  106. user.set_password(password)
  107. user.save()
  108. html = render_template('templet/forget.html', confirm_url=password)
  109. subject = "Please update your password in time"
  110. user.send_email(html=html, subject=subject)
  111. return HTTPResponse(HTTPResponse.NORMAL_STATUS).to_response()
  112. class ConfirmView(MethodView):
  113. @login_required
  114. def post(self):
  115. user = request.user
  116. if user.is_confirmed:
  117. return HTTPResponse(
  118. HTTPResponse.AUTH_USER_IS_CONFIRMED).to_response()
  119. if not user.email_is_allowed:
  120. msg = "user isn't allowed to send email"
  121. return HTTPResponse(
  122. HTTPResponse.AUTH_USER_IS_CONFIRMED, message=msg).to_response()
  123. token = user.email_token
  124. confirm_url = url_for(
  125. 'auth.confirm_token', token=token, _external=True)
  126. html = render_template('templet/email.html', confirm_url=confirm_url)
  127. subject = _("Please confirm your email")
  128. user.send_email(html=html, subject=subject)
  129. return HTTPResponse(
  130. HTTPResponse.NORMAL_STATUS, message='send success').to_response()
  131. class ConfirmTokenView(MethodView):
  132. def get(self, token):
  133. user = User.check_email_token(token)
  134. if not user:
  135. return HTTPResponse(
  136. HTTPResponse.AUTH_TOKEN_VERIFY_FAIL).to_response()
  137. if user.is_confirmed:
  138. return HTTPResponse(
  139. HTTPResponse.AUTH_USER_IS_CONFIRMED).to_response()
  140. user.is_confirmed = True
  141. user.save()
  142. return HTTPResponse(HTTPResponse.NORMAL_STATUS).to_response()