def register(): if current_user.is_authenticated: #если пользователь уже авторизован return redirect( url_for('main.home') ) #нет смысла регистрировать его снова, перенаправляем на домашнюю страницу form = RegistrationForm() #создаём экземпляр регистрационной формы if form.validate_on_submit(): #если введённая информация корректна hashed_password = bcrypt.generate_password_hash( form.password.data ).decode( 'utf-8' ) #хэшируем пароль пользователя и переводим его в понятный буквенно-цифровой вид user = User( username=form.username.data, email=form.email.data, password=hashed_password ) #создаём юзера с данными из формы (но с шифрованным паролем) db.session.add(user) #добавляем нового пользователя в БД db.session.commit() #комиттим изменения flash(f'Account created for {form.username.data}!', 'success') #выдаём сообщение об успешной регистрации return redirect( url_for('users.login')) #перенаправляем юзера на домашнюю страницу return render_template( 'register.html', title='Register', form=form) #отправляем юзеру страницу с формой регистрации
def reset_token(token): if current_user.is_authenticated: return redirect(url_for('main.home')) user = User.verify_reset_token(token) if user is None: flash('That is an invalid or expired token', 'warning') return redirect(url_for('users.reset_request')) form = ResetPasswordForm() if form.validate_on_submit(): #если введённая информация корректна hashed_password = bcrypt.generate_password_hash( form.password.data ).decode( 'utf-8' ) #хэшируем пароль пользователя и переводим его в понятный буквенно-цифровой вид user.password = hashed_password db.session.commit() #комиттим изменения flash(f'Your password has been updated.', 'success') #выдаём сообщение об успешной регистрации return redirect( url_for('users.login')) #перенаправляем юзера на домашнюю страницу return render_template('reset_token.html', title='Reset Password', form=form)
def register(): if current_user.is_authenticated: return redirected(url_for('home')) form = RegistrationForm() if form.validate_on_submit(): hashed_password=bcrypt.generate_password_hash(form.password.data).decode('utf-8') user=User(username=form.username.data, email=form.email.data, password=hashed_password) db.session.add(user) db.session.commit() flash(f'Your account has been created! You are now able to log in', 'success') return redirect(url_for('login')) return render_template('register.html',title='Register',form=form)
def register(): if current_user.is_authenticated: return redirect(url_for('main.home')) form = RegistrationForm() if form.validate_on_submit(): hashed_pw = bcrypt.generate_password_hash( form.password.data).decode('utf-8') user = User(username=form.username.data, email=form.email.data, password=hashed_pw) db.session.add(user) db.session.commit() flash(f'Account created for {form.username.data}!', 'success') return redirect(url_for('users.login')) # print(form.errors) return render_template('register.html', title='Register', form=form)
def reset_token(token): if current_user.is_authenticated: return redirect(url_for('main.home')) user = User.verify_reset_token(token) if user is None: flash('Invalid or expired token', 'warning') return redirect(url_for('users.reset_request')) form = ResetPasswordForm() if form.validate_on_submit(): hashed_pw = bcrypt.generate_password_hash( form.password.data).decode('utf-8') user.password = hashed_pw db.session.commit() flash(f'Password updated!', 'success') return redirect(url_for('users.login')) return render_template('reset_token.html', title='Reset Password', form=form)
def register(): """ register function that displays the registration page """ if current_user.is_authenticated: return redirect(url_for('home')) form = RegistrationForm() if form.validate_on_submit(): # one time alert use flash hashed_password = bcrypt.generate_password_hash( form.password.data).decode('utf-8') user = User(username=form.username.data, email=form.email.data, password=hashed_password) db.session.add(user) db.session.commit() # adding user to the database flash(f'Your account has been successfully created you can now login', 'success') return redirect(url_for('login')) return render_template('register.html', title='Register', form=form)