routes.py 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. # -*- encoding: utf-8 -*-
  2. """
  3. Copyright (c) 2019 - present AppSeed.us
  4. """
  5. from flask import render_template, redirect, request, url_for
  6. from flask_login import (
  7. current_user,
  8. login_user,
  9. logout_user
  10. )
  11. from apps import db, login_manager
  12. from apps.authentication import blueprint
  13. from apps.authentication.forms import LoginForm, CreateAccountForm
  14. from apps.authentication.models import Users
  15. from apps.authentication.util import verify_pass
  16. @blueprint.route('/')
  17. def route_default():
  18. return redirect(url_for('authentication_blueprint.login'))
  19. # Login & Registration
  20. @blueprint.route('/login', methods=['GET', 'POST'])
  21. def login():
  22. login_form = LoginForm(request.form)
  23. if 'login' in request.form:
  24. # read form data
  25. username = request.form['username']
  26. password = request.form['password']
  27. # Locate user
  28. user = Users.query.filter_by(username=username).first()
  29. # Check the password
  30. if user and verify_pass(password, user.password):
  31. login_user(user)
  32. return redirect(url_for('authentication_blueprint.route_default'))
  33. # Something (user or pass) is not ok
  34. return render_template('accounts/login.html',
  35. msg='Wrong user or password',
  36. form=login_form)
  37. if not current_user.is_authenticated:
  38. return render_template('accounts/login.html',
  39. form=login_form)
  40. return redirect(url_for('home_blueprint.index'))
  41. @blueprint.route('/register', methods=['GET', 'POST'])
  42. def register():
  43. create_account_form = CreateAccountForm(request.form)
  44. if 'register' in request.form:
  45. username = request.form['username']
  46. email = request.form['email']
  47. # Check usename exists
  48. user = Users.query.filter_by(username=username).first()
  49. if user:
  50. return render_template('accounts/register.html',
  51. msg='Username already registered',
  52. success=False,
  53. form=create_account_form)
  54. # Check email exists
  55. user = Users.query.filter_by(email=email).first()
  56. if user:
  57. return render_template('accounts/register.html',
  58. msg='Email already registered',
  59. success=False,
  60. form=create_account_form)
  61. # else we can create the user
  62. user = Users(**request.form)
  63. db.session.add(user)
  64. db.session.commit()
  65. return render_template('accounts/register.html',
  66. msg='User created please <a href="/login">login</a>',
  67. success=True,
  68. form=create_account_form)
  69. else:
  70. return render_template('accounts/register.html', form=create_account_form)
  71. @blueprint.route('/logout')
  72. def logout():
  73. logout_user()
  74. return redirect(url_for('authentication_blueprint.login'))
  75. # Errors
  76. @login_manager.unauthorized_handler
  77. def unauthorized_handler():
  78. return render_template('home/page-403.html'), 403
  79. @blueprint.errorhandler(403)
  80. def access_forbidden(error):
  81. return render_template('home/page-403.html'), 403
  82. @blueprint.errorhandler(404)
  83. def not_found_error(error):
  84. return render_template('home/page-404.html'), 404
  85. @blueprint.errorhandler(500)
  86. def internal_error(error):
  87. return render_template('home/page-500.html'), 500