Files
notifications-admin/app/main/views/code_not_received.py

66 lines
2.3 KiB
Python

from flask import redirect, render_template, request, session, url_for
from app import user_api_client
from app.main import main
from app.main.forms import TextNotReceivedForm
from app.models.user import User
from app.utils.login import redirect_to_sign_in
@main.route("/resend-email-verification")
@redirect_to_sign_in
def resend_email_verification():
user = User.from_email_address(session["user_details"]["email"])
user.send_verify_email()
return render_template(
"views/resend-email-verification.html", email=user.email_address
)
@main.route("/text-not-received", methods=["GET", "POST"])
@redirect_to_sign_in
def check_and_resend_text_code():
user = User.from_email_address(session["user_details"]["email"])
redirect_url = request.args.get("next")
if user.state == "active":
# this is a verified user and therefore redirect to page to request resend without edit mobile
return render_template(
"views/verification-not-received.html", redirect_url=redirect_url
)
form = TextNotReceivedForm(mobile_number=user.mobile_number)
if form.validate_on_submit():
user.send_verify_code(to=form.mobile_number.data)
user.update(mobile_number=form.mobile_number.data)
return redirect(url_for(".verify", next=redirect_url))
return render_template("views/text-not-received.html", form=form)
@main.route("/send-new-code", methods=["GET"])
@redirect_to_sign_in
def check_and_resend_verification_code():
user = User.from_email_address(session["user_details"]["email"])
user.send_verify_code()
redirect_url = request.args.get("next")
if user.state == "pending":
return redirect(url_for("main.verify", next=redirect_url))
else:
return redirect(url_for("main.two_factor_sms", next=redirect_url))
@main.route("/email-not-received", methods=["GET"])
@redirect_to_sign_in
def email_not_received():
redirect_url = request.args.get("next")
return render_template("views/email-not-received.html", redirect_url=redirect_url)
@main.route("/send-new-email-token", methods=["GET"])
@redirect_to_sign_in
def resend_email_link():
user_api_client.send_verify_code(session["user_details"]["id"], "email", None)
session.pop("user_details")
return redirect(url_for("main.two_factor_email_sent", email_resent=True))