2016-01-05 17:08:50 +00:00
|
|
|
from flask import (
|
|
|
|
|
render_template, redirect, jsonify, session, url_for)
|
2015-12-15 11:06:09 +00:00
|
|
|
|
|
|
|
|
from app.main import main
|
2015-12-31 11:13:42 +00:00
|
|
|
from app.main.dao import users_dao
|
2015-12-15 15:35:30 +00:00
|
|
|
from app.main.forms import EmailNotReceivedForm, TextNotReceivedForm
|
|
|
|
|
from app.main.views import send_sms_code, send_email_code
|
2015-12-15 11:06:09 +00:00
|
|
|
|
|
|
|
|
|
2016-01-05 17:08:50 +00:00
|
|
|
@main.route('/email-not-received', methods=['GET', 'POST'])
|
2015-12-15 11:06:09 +00:00
|
|
|
def check_and_resend_email_code():
|
2016-01-05 17:08:50 +00:00
|
|
|
# TODO there needs to be a way to regenerate a session id
|
2016-01-07 12:43:10 +00:00
|
|
|
user = users_dao.get_user_by_email(session['user_email'])
|
2016-01-05 17:08:50 +00:00
|
|
|
form = EmailNotReceivedForm(email_address=user.email_address)
|
2015-12-15 15:35:30 +00:00
|
|
|
if form.validate_on_submit():
|
|
|
|
|
users_dao.update_email_address(id=user.id, email_address=form.email_address.data)
|
|
|
|
|
send_email_code(user_id=user.id, email=user.email_address)
|
2016-01-05 17:08:50 +00:00
|
|
|
return redirect(url_for('.verify'))
|
|
|
|
|
return render_template('views/email-not-received.html', form=form)
|
2015-12-15 11:06:09 +00:00
|
|
|
|
|
|
|
|
|
2016-01-05 17:08:50 +00:00
|
|
|
@main.route('/text-not-received', methods=['GET', 'POST'])
|
2015-12-15 11:06:09 +00:00
|
|
|
def check_and_resend_text_code():
|
2016-01-05 17:08:50 +00:00
|
|
|
# TODO there needs to be a way to regenerate a session id
|
2016-01-07 12:43:10 +00:00
|
|
|
user = users_dao.get_user_by_email(session['user_email'])
|
2016-01-05 17:08:50 +00:00
|
|
|
form = TextNotReceivedForm(mobile_number=user.mobile_number)
|
2015-12-15 15:35:30 +00:00
|
|
|
if form.validate_on_submit():
|
|
|
|
|
users_dao.update_mobile_number(id=user.id, mobile_number=form.mobile_number.data)
|
|
|
|
|
send_sms_code(user_id=user.id, mobile_number=user.mobile_number)
|
2016-01-05 17:08:50 +00:00
|
|
|
return redirect(url_for('.verify'))
|
|
|
|
|
return render_template('views/text-not-received.html', form=form)
|
2015-12-31 11:13:42 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
@main.route('/verification-not-received', methods=['GET'])
|
|
|
|
|
def verification_code_not_received():
|
|
|
|
|
return render_template('views/verification-not-received.html')
|
|
|
|
|
|
|
|
|
|
|
2015-12-31 13:16:59 +00:00
|
|
|
@main.route('/send-new-code', methods=['GET'])
|
2015-12-31 11:13:42 +00:00
|
|
|
def check_and_resend_verification_code():
|
2016-01-05 17:08:50 +00:00
|
|
|
# TODO there needs to be a way to generate a new session id
|
2016-01-07 12:43:10 +00:00
|
|
|
user = users_dao.get_user_by_email(session['user_email'])
|
2015-12-31 11:13:42 +00:00
|
|
|
send_sms_code(user.id, user.mobile_number)
|
2016-01-05 17:08:50 +00:00
|
|
|
return redirect(url_for('main.two_factor'))
|