示例#1
0
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)  #отправляем юзеру страницу с формой регистрации
示例#2
0
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)
示例#3
0
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)
示例#4
0
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)
示例#5
0
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)
示例#6
0
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)