def home(): players_pattern = get_player_pattern() if (request.method == 'POST'): return nav_search() page = request.args.get('page', 1, type=int) posts = Post.query.order_by(Post.date_posted.desc()).paginate(page=page, per_page=5) return render_template('home.html', posts=posts, players_pattern=players_pattern)
def user_posts(username): players_pattern = get_player_pattern() page = request.args.get('page', 1, type=int) user = User.query.filter_by(username=username).first_or_404() posts = Post.query.filter_by(author=user)\ .order_by(Post.date_posted.desc())\ .paginate(page=page, per_page=5) if (request.method == 'POST'): return nav_search() return render_template('user_posts.html', posts=posts, user=user, players_pattern=players_pattern)
def delete_post(post_id): players_pattern = get_player_pattern() print(players_pattern) post = Post.query.get_or_404(post_id) if post.author != current_user: abort(403) db.session.delete(post) db.session.commit() flash('Your post has been deleted!', 'success') if (request.method == 'POST'): return nav_search() return redirect(url_for('main.home'))
def reset_request(): players_pattern = get_player_pattern() 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) flash('An email has been sent with instructions to reset your password.', 'info') return redirect(url_for('users.login')) if (request.method == 'POST'): return nav_search() return render_template('reset_request.html', title='Reset Password', form=form, players_pattern=players_pattern)
def post(post_id): players_pattern = get_player_pattern() print(players_pattern) if (request.method == 'POST'): name = request.form["player"] if (get_player_attributes(name) == 0): flash('enter a valid name', 'danger') return redirect(url_for('main.home')) post = Post.query.get_or_404(post_id) if (request.method == 'POST'): return nav_search() return render_template('post.html', title=post.title, post=post, players_pattern=players_pattern)
def nav_search(): player_form = PlayerForm(request.form) players_pattern = get_player_pattern() session['playername'] = request.form['player'] if player_form.validate(): if (get_player_attributes(request.form["player"]) == 0): flash('enter a valid name', 'danger') page = request.args.get('page', 1, type=int) posts = Post.query.order_by(Post.date_posted.desc()).paginate(page=page, per_page=5) return render_template('home.html', posts=posts,players_pattern=players_pattern) else: return redirect(url_for('stats.player', name=request.form["player"])) else: flash('enter a valid name', 'danger') page = request.args.get('page', 1, type=int) posts = Post.query.order_by(Post.date_posted.desc()).paginate(page=page, per_page=5) return render_template('home.html', posts=posts, players_pattern=players_pattern)
def new_post(): players_pattern = get_player_pattern() form = PostForm() if form.validate_on_submit(): post = Post(title=form.title.data, content=form.content.data, author=current_user) db.session.add(post) db.session.commit() flash('Your post has been created!', 'success') return redirect(url_for('main.home')) if (request.method == 'POST'): return nav_search() return render_template('create_post.html', title='New Post', form=form, legend='New Post', players_pattern=players_pattern)
def register(): flag = 0 players_pattern = get_player_pattern() form = RegistrationForm() if (form.validate_on_submit and request.method == 'POST' and form.password.data): flag = 1 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('Your account has been created! You are now able to log in', 'success') return redirect(url_for('users.login')) if (request.method == 'POST' and flag == 0): return nav_search() return render_template('register.html', title='Register', form=form, players_pattern=players_pattern)
def login(): flag = 0 players_pattern = get_player_pattern() 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') return redirect(next_page) if next_page else redirect(url_for('main.home')) else: flag = 1 flash('Login Unsuccessful. Please check email and password', 'danger') if (request.method == 'POST' and flag == 0): return nav_search() return render_template('login.html', title='Login', form=form, players_pattern=players_pattern)
def reset_token(token): players_pattern = get_player_pattern() 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('Your password has been updated! You are now able to log in', 'success') return redirect(url_for('users.login')) if (request.method == 'POST'): return nav_search() return render_template('reset_token.html', title='Reset Password', form=form, players_pattern=players_pattern)
def account(): players_pattern = get_player_pattern() 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('Your account has been updated!', 'success') 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) if (request.method == 'POST'): return nav_search() return render_template('account.html', title='Account', image_file=image_file, form=form, players_pattern=players_pattern)
def update_post(post_id): players_pattern = get_player_pattern() print(players_pattern) 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('Your post has been updated!', 'success') return redirect(url_for('posts.post', post_id=post.id)) elif request.method == 'GET': form.title.data = post.title form.content.data = post.content if (request.method == 'POST'): return nav_search() return render_template('create_post.html', title='Update Post', form=form, legend='Update Post', players_pattern=players_pattern)