Example #1
0
def delete_post(post_id):
    post = Post.query.get_or_404(post_id)
    if post.author != current_user:
        abort(403)
    db.session.delete(post)
    db.session.commit()
    flash('Successfully deleted a post!', 'success')
    logger.info(f'Deleted post {post.title} by user: {post.author}')
    return redirect(url_for('main.home'))
Example #2
0
def new_post():
    form = PostForm()
    if form.validate_on_submit():
        save_valid_post(form)
        flash('Successfully created new post!', 'success')
        logger.info(f'Added new post {form.title} by user: {current_user}')
        return redirect(url_for('main.home'))
    return render_template('create_post.html',
                           title='New Post',
                           form=form,
                           legend='New Post',
                           today=date.today())
def register():
    if current_user.is_authenticated:
        return redirect(url_for('main.home'))
    form = RegistrationForm()
    if form.validate_on_submit():
        save_valid_user(form)
        new_user = form.username.data
        logger.info(f'Registered new user: {new_user}')
        flash(f'Successfully created account for {new_user}!', 'success')
        return redirect(url_for('users.login'))
    return render_template('register.html',
                           title='Register',
                           form=form,
                           today=date.today())
def reset_request():
    if current_user.is_authenticated:
        return redirect(url_for('main.home'))
    form = RequestResetForm()
    if form.validate_on_submit():
        user = User.query.filter_by(email=form.email.data).first()
        send_reset_email(user)
        logger.info(
            f'Email with password reset token was send to user: {user.username}'
        )
        flash(
            'An email has been sent with instructions to reset your password.',
            'info')
        return redirect(url_for('users.login'))
    return render_template('reset_request.html',
                           title='Reset Password',
                           form=form,
                           today=date.today())
def login():
    if current_user.is_authenticated:
        return redirect(url_for('main.home'))
    form = LoginForm()
    if form.validate_on_submit():
        user = User.query.filter_by(email=form.email.data).first()
        if user and bcrypt.check_password_hash(user.password,
                                               form.password.data):
            login_user(user, remember=form.remember.data)
            next_page = request.args.get('next')
            logger.info(f'Logged user: {user.username}')
            return redirect(next_page) if next_page else redirect(
                url_for('main.home'))
        else:
            flash('Invalid email or password!', 'danger')
    return render_template('login.html',
                           title='Login',
                           form=form,
                           today=date.today())
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_password = bcrypt.generate_password_hash(
            form.password.data).decode('utf-8')
        user.password = hashed_password
        db.session.commit()
        logger.info(f'Password changed for user: {user}')
        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,
                           today=date.today())
Example #7
0
def update_post(post_id):
    post = Post.query.get_or_404(post_id)
    if post.author != current_user:
        abort(403)
    form = PostForm()
    if form.validate_on_submit():
        post.title = form.title.data
        post.content = form.content.data
        db.session.commit()
        flash('Successfully updated a post!', 'success')
        logger.info(f'Updated post {post.title} by user: {post.author}')
        return redirect(url_for('posts.post', post_id=post.id))
    elif request.method == 'GET':
        form.title.data = post.title
        form.content.data = post.content
    return render_template('create_post.html',
                           title='Update Post',
                           form=form,
                           legend='Update Post',
                           today=date.today())
def account():
    form = UpdateAccountForm()
    if form.validate_on_submit():
        if form.picture.data:
            picture_file = save_picture(form.picture.data)
            current_user.image_file = picture_file
        current_user.username = form.username.data
        current_user.email = form.email.data
        db.session.commit()
        flash('Successfully Updated Account!', 'success')
        logger.info(f'Updated account for user: {current_user.username}')
        return redirect(url_for('users.account'))
    elif request.method == 'GET':
        form.username.data = current_user.username
        form.email.data = current_user.email
    image_file = url_for('static',
                         filename='profile_pics/' + current_user.image_file)
    return render_template('account.html',
                           title='Account',
                           image_file=image_file,
                           form=form,
                           today=date.today())