from flask import redirect, render_template, 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 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']) 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') 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')) 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() if user.state == 'pending': return redirect(url_for('main.verify')) else: return redirect(url_for('main.two_factor')) @main.route('/email-not-received', methods=['GET']) @redirect_to_sign_in def email_not_received(): return render_template('views/email-not-received.html') @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))