2016-03-07 18:18:52 +00:00
|
|
|
import json
|
2018-02-20 11:22:17 +00:00
|
|
|
from datetime import datetime
|
2016-03-07 18:18:52 +00:00
|
|
|
|
2018-02-20 11:22:17 +00:00
|
|
|
from flask import (
|
|
|
|
|
current_app,
|
|
|
|
|
flash,
|
|
|
|
|
redirect,
|
|
|
|
|
render_template,
|
|
|
|
|
session,
|
|
|
|
|
url_for,
|
|
|
|
|
)
|
2016-03-07 18:18:52 +00:00
|
|
|
from itsdangerous import SignatureExpired
|
2017-11-01 14:39:14 +00:00
|
|
|
from notifications_utils.url_safe_token import check_token
|
2016-01-05 17:52:09 +00:00
|
|
|
|
2017-11-01 14:39:14 +00:00
|
|
|
from app import user_api_client
|
2016-01-05 17:52:09 +00:00
|
|
|
from app.main import main
|
2016-01-06 17:37:07 +00:00
|
|
|
from app.main.forms import NewPasswordForm
|
2017-11-28 15:25:29 +00:00
|
|
|
from app.main.views.two_factor import log_in_user
|
2016-01-06 17:37:07 +00:00
|
|
|
|
2016-01-05 17:52:09 +00:00
|
|
|
|
2016-01-06 17:37:07 +00:00
|
|
|
@main.route('/new-password/<path:token>', methods=['GET', 'POST'])
|
|
|
|
|
def new_password(token):
|
2016-03-07 18:18:52 +00:00
|
|
|
try:
|
|
|
|
|
token_data = check_token(token, current_app.config['SECRET_KEY'], current_app.config['DANGEROUS_SALT'],
|
2017-11-01 14:39:14 +00:00
|
|
|
current_app.config['EMAIL_EXPIRY_SECONDS'])
|
2016-03-07 18:18:52 +00:00
|
|
|
except SignatureExpired:
|
2016-01-08 16:47:34 +00:00
|
|
|
flash('The link in the email we sent you has expired. Enter your email address to resend.')
|
2016-01-08 15:12:14 +00:00
|
|
|
return redirect(url_for('.forgot_password'))
|
|
|
|
|
|
2016-03-07 18:18:52 +00:00
|
|
|
email_address = json.loads(token_data)['email']
|
2016-03-30 09:58:10 +01:00
|
|
|
user = user_api_client.get_user_by_email(email_address)
|
2016-03-07 18:18:52 +00:00
|
|
|
if user.password_changed_at and datetime.strptime(user.password_changed_at, '%Y-%m-%d %H:%M:%S.%f') > \
|
|
|
|
|
datetime.strptime(json.loads(token_data)['created_at'], '%Y-%m-%d %H:%M:%S.%f'):
|
|
|
|
|
flash('The link in the email has already been used')
|
|
|
|
|
return redirect(url_for('main.index'))
|
2016-01-08 15:12:14 +00:00
|
|
|
|
2016-01-06 17:37:07 +00:00
|
|
|
form = NewPasswordForm()
|
2016-01-08 15:12:14 +00:00
|
|
|
|
2016-01-06 17:37:07 +00:00
|
|
|
if form.validate_on_submit():
|
2017-02-28 14:41:31 +00:00
|
|
|
user_api_client.reset_failed_login_count(user.id)
|
2016-01-27 16:30:33 +00:00
|
|
|
session['user_details'] = {
|
|
|
|
|
'id': user.id,
|
|
|
|
|
'email': user.email_address,
|
|
|
|
|
'password': form.new_password.data}
|
2017-11-28 15:25:29 +00:00
|
|
|
if user.auth_type == 'email_auth':
|
|
|
|
|
# they've just clicked an email link, so have done an email auth journey anyway. Just log them in.
|
|
|
|
|
return log_in_user(user.id)
|
|
|
|
|
else:
|
|
|
|
|
# send user a 2fa sms code
|
|
|
|
|
user_api_client.send_verify_code(user.id, 'sms', user.mobile_number)
|
|
|
|
|
return redirect(url_for('main.two_factor'))
|
2016-01-06 17:37:07 +00:00
|
|
|
else:
|
2016-01-08 15:12:14 +00:00
|
|
|
return render_template('views/new-password.html', token=token, form=form, user=user)
|