2016-01-05 17:08:50 +00:00
|
|
|
from flask import (
|
2016-01-19 22:47:42 +00:00
|
|
|
render_template,
|
|
|
|
|
redirect,
|
|
|
|
|
session,
|
2016-01-20 15:13:15 +00:00
|
|
|
url_for,
|
|
|
|
|
abort
|
2016-01-19 22:47:42 +00:00
|
|
|
)
|
2016-01-05 13:13:06 +00:00
|
|
|
|
2016-01-20 15:13:15 +00:00
|
|
|
from client.errors import HTTPError
|
|
|
|
|
|
2015-12-07 16:08:30 +00:00
|
|
|
from flask_login import login_user
|
2015-12-04 16:21:01 +00:00
|
|
|
|
2015-12-07 16:08:30 +00:00
|
|
|
from app.main import main
|
2016-01-27 12:22:32 +00:00
|
|
|
from app.main.dao import users_dao
|
2015-12-04 16:21:01 +00:00
|
|
|
from app.main.forms import VerifyForm
|
|
|
|
|
|
|
|
|
|
|
2016-01-05 17:08:50 +00:00
|
|
|
@main.route('/verify', methods=['GET', 'POST'])
|
|
|
|
|
def verify():
|
|
|
|
|
# TODO there needs to be a way to regenerate a session id
|
2016-01-05 17:24:13 +00:00
|
|
|
# or handle gracefully.
|
2016-01-19 22:47:42 +00:00
|
|
|
user_id = session['user_details']['id']
|
|
|
|
|
|
2016-01-27 12:22:32 +00:00
|
|
|
def _check_code(code, code_type):
|
|
|
|
|
return users_dao.check_verify_code(user_id, code, code_type)
|
|
|
|
|
form = VerifyForm(_check_code)
|
|
|
|
|
if form.validate_on_submit():
|
2016-01-20 15:13:15 +00:00
|
|
|
try:
|
|
|
|
|
user = users_dao.get_user_by_id(user_id)
|
|
|
|
|
activated_user = users_dao.activate_user(user)
|
|
|
|
|
login_user(activated_user)
|
|
|
|
|
return redirect(url_for('main.add_service', first='first'))
|
|
|
|
|
except HTTPError as e:
|
|
|
|
|
if e.status_code == 404:
|
|
|
|
|
abort(404)
|
|
|
|
|
else:
|
|
|
|
|
raise e
|
2016-01-19 22:47:42 +00:00
|
|
|
|
2016-01-05 17:24:13 +00:00
|
|
|
return render_template('views/verify.html', form=form)
|