views.py 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  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-1 21:59:10 (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. class LoginView(MethodView):
  26. def get(self):
  27. form = LoginForm()
  28. data = {'form': form}
  29. return render_template('auth/login.html', **data)
  30. @form_validate(LoginForm)
  31. def post(self):
  32. form = LoginForm()
  33. post_data = form.data
  34. username = post_data.pop('username', None)
  35. password = post_data.pop('password', None)
  36. remember = post_data.pop('remember', None)
  37. remember = True if remember else None
  38. user = User.query.filter_by(username=username).first()
  39. if user and user.check_password(password):
  40. login_user(user, remember=remember)
  41. identity_changed.send(
  42. current_app._get_current_object(), identity=Identity(user.id))
  43. serializer = Serializer(user, many=False, depth=1)
  44. return HTTPResponse(
  45. HTTPResponse.NORMAL_STATUS, data=serializer.data).to_response()
  46. return HTTPResponse(
  47. HTTPResponse.AUTH_USER_OR_PASSWORD_ERROR).to_response()
  48. class LogoutView(MethodView):
  49. @login_required
  50. def get(self):
  51. logout_user()
  52. identity_changed.send(
  53. current_app._get_current_object(), identity=AnonymousIdentity())
  54. return redirect(request.args.get('next') or '/')
  55. class RegisterView(MethodView):
  56. def get(self):
  57. form = RegisterForm()
  58. data = {'form': form}
  59. return render_template('auth/register.html', **data)
  60. @form_validate(RegisterForm)
  61. def post(self):
  62. form = RegisterForm()
  63. post_data = form.data
  64. username = post_data.pop('username', None)
  65. email = post_data.pop('email', None)
  66. password = post_data.pop('password', None)
  67. user = User.query.filter_by(username=username).first()
  68. if user is not None:
  69. return HTTPResponse(HTTPResponse.AUTH_USERNAME_UNIQUE).to_response(
  70. )
  71. user = User.query.filter_by(email=email).first()
  72. if user is not None:
  73. return HTTPResponse(HTTPResponse.AUTH_EMAIL_UNIQUE).to_response()
  74. user = User(username=username, email=email)
  75. user.set_password(password)
  76. user.save()
  77. login_user(user)
  78. self.email(user)
  79. return HTTPResponse(HTTPResponse.NORMAL_STATUS).to_response()
  80. def email(self, user):
  81. token = user.email_token
  82. confirm_url = url_for(
  83. 'auth.confirm_token', token=token, _external=True)
  84. html = render_template('templet/email.html', confirm_url=confirm_url)
  85. subject = _("Please confirm your email!")
  86. user.send_email(subject=subject, html=html)
  87. class ForgetView(MethodView):
  88. def get(self):
  89. form = ForgetForm()
  90. data = {'form': form}
  91. return render_template('auth/forget.html', **data)
  92. @form_validate(ForgetForm)
  93. def post(self):
  94. form = ForgetForm()
  95. post_data = form.data
  96. email = post_data.pop('email', None)
  97. user = User.query.filter_by(email=email).first()
  98. if not user:
  99. return HTTPResponse(
  100. HTTPResponse.AUTH_EMAIL_NOT_REGISTER).to_response()
  101. password = ''.join(sample(ascii_letters + digits, 12))
  102. user.set_password(password)
  103. user.save()
  104. html = render_template('templet/forget.html', confirm_url=password)
  105. subject = "Please update your password in time"
  106. user.send_email(html=html, subject=subject)
  107. return HTTPResponse(HTTPResponse.NORMAL_STATUS).to_response()
  108. class ConfirmView(MethodView):
  109. @login_required
  110. def post(self):
  111. user = request.user
  112. if user.is_confirmed:
  113. return HTTPResponse(
  114. HTTPResponse.AUTH_USER_IS_CONFIRMED).to_response()
  115. if not user.email_is_allowed:
  116. msg = "user isn't allowed to send email"
  117. return HTTPResponse(
  118. HTTPResponse.AUTH_USER_IS_CONFIRMED, message=msg).to_response()
  119. token = user.email_token
  120. confirm_url = url_for(
  121. 'auth.confirm_token', token=token, _external=True)
  122. html = render_template('templet/email.html', confirm_url=confirm_url)
  123. subject = _("Please confirm your email")
  124. user.send_email(html=html, subject=subject)
  125. return HTTPResponse(
  126. HTTPResponse.NORMAL_STATUS, message='send success').to_response()
  127. class ConfirmTokenView(MethodView):
  128. def get(self, token):
  129. user = User.check_email_token(token)
  130. if not user:
  131. return HTTPResponse(
  132. HTTPResponse.AUTH_TOKEN_VERIFY_FAIL).to_response()
  133. if user.is_confirmed:
  134. return HTTPResponse(
  135. HTTPResponse.AUTH_USER_IS_CONFIRMED).to_response()
  136. user.is_confirmed = True
  137. user.save()
  138. return HTTPResponse(HTTPResponse.NORMAL_STATUS).to_response()