|
|
- from flask import render_template, redirect, url_for, flash, request, \
- current_app, abort, make_response
- from flask_login import login_required, current_user
- from . import main
- from .forms import EditProfileForm, EditProfileAdminForm, PostForm
- from .. import db
- from ..models import User, Role, Permission, Post
- from ..decorators import admin_required, permission_required
-
-
- @main.route('/', methods=['GET', 'POST'])
- def index():
- form = PostForm()
- if current_user.can(Permission.WRITE) and form.validate_on_submit():
- post = Post(body=form.body.data,
- author=current_user._get_current_object())
- db.session.add(post)
- db.session.commit()
- return redirect(url_for('.index'))
- page = request.args.get('page', 1, type=int)
- show_followed = False
- if current_user.is_authenticated:
- show_followed = bool(request.cookies.get('show_followed', ''))
- if show_followed:
- query = current_user.followed_posts
- else:
- query = Post.query
- pagination = query.order_by(Post.timestamp.desc()).paginate(
- page, per_page=current_app.config['FLASKY_POSTS_PER_PAGE'],
- error_out=False)
- posts = pagination.items
- return render_template('index.html', form=form, posts=posts,
- show_followed=show_followed, pagination=pagination)
-
-
- @main.route('/user/<username>')
- def user(username):
- user = User.query.filter_by(username=username).first_or_404()
- page = request.args.get('page', 1, type=int)
- pagination = user.posts.order_by(Post.timestamp.desc()).paginate(
- page, per_page=current_app.config['FLASKY_POSTS_PER_PAGE'],
- error_out=False)
- posts = pagination.items
- return render_template('user.html', user=user, posts=posts,
- pagination=pagination)
-
-
- @main.route('/edit-profile', methods=['GET', 'POST'])
- @login_required
- def edit_profile():
- form = EditProfileForm()
- if form.validate_on_submit():
- current_user.name = form.name.data
- current_user.location = form.location.data
- current_user.about_me = form.about_me.data
- db.session.add(current_user._get_current_object())
- db.session.commit()
- flash('Your profile has been updated.')
- return redirect(url_for('.user', username=current_user.username))
- form.name.data = current_user.name
- form.location.data = current_user.location
- form.about_me.data = current_user.about_me
- return render_template('edit_profile.html', form=form)
-
-
- @main.route('/edit-profile/<int:id>', methods=['GET', 'POST'])
- @login_required
- @admin_required
- def edit_profile_admin(id):
- user = User.query.get_or_404(id)
- form = EditProfileAdminForm(user=user)
- if form.validate_on_submit():
- user.email = form.email.data
- user.username = form.username.data
- user.comfirmed = form.confirmed.data
- user.role = Role.query.get(form.role.data)
- user.name = form.name.data
- user.location = form.location.data
- user.about_me = form.about_me.data
- db.session.add(user)
- db.session.commit()
- flash('The profile has been updated.')
- return redirect(url_for('.user', username=user.username))
- form.email.data = user.email
- form.username.data = user.username
- form.confirmed.data = user.confirmed
- form.role.data = user.role_id
- form.name.data = user.name
- form.location.data = user.location
- form.about_me.data = user.about_me
- return render_template('edit_profile.html', form=form, user=user)
-
-
- @main.route('/post/<int:id>')
- def post(id):
- post = Post.query.get_or_404(id)
- return render_template('post.html', posts=[post])
-
-
- @main.route('/edit/<int:id>', methods=['GET', 'POST'])
- @login_required
- def edit(id):
- post = Post.query.get_or_404(id)
- if current_user != post.author and \
- not current_user.can(Permission.ADMIN):
- abort(403)
- form = PostForm()
- if form.validate_on_submit():
- post.body = form.body.data
- db.session.add(post)
- db.session.commit()
- flash('The post has been updated.')
- return redirect(url_for('.post', id=post.id))
- form.body.data = post.body
- return render_template('edit_post.html', form=form)
-
-
- @main.route('/follow/<username>')
- @login_required
- @permission_required(Permission.FOLLOW)
- def follow(username):
- user = User.query.filter_by(username=username).first()
- if user is None:
- flash('Invalid user')
- return redirect(url_for('.index'))
- if current_user.is_following(user):
- flash('You are already follwoing this user.')
- return redirect(url_for('.user', username=username))
- current_user.follow(user)
- db.session.commit()
- flash('You are now following %s' % username)
- return redirect(url_for('.user', username=username))
-
-
- @main.route('/unfollow/<username>')
- @login_required
- @permission_required(Permission.FOLLOW)
- def unfollow(username):
- user = User.query.filter_by(username=username).first()
- if user is None:
- flash('Invalid user')
- return redirect(url_for('.index'))
- if not current_user.is_following(user):
- flash('You are not following this user.')
- return redirect(url_for('.user', username=username))
- current_user.unfollow(user)
- db.session.commit()
- flash('You are not following %s anymore' % username)
- return redirect(url_for('.user', username=username))
-
-
- @main.route('/followers/<username>')
- def followers(username):
- user = User.query.filter_by(username=username).first()
- if user is None:
- flash('Invalid user')
- return redirect(url_for('.index'))
- page = request.args.get('page', 1, type=int)
- pagination = user.followers.paginate(
- page, per_page=current_app.config['FLASKY_FOLLOWERS_PER_PAGE'],
- error_out=False)
- follows = [{'user': item.follower, 'timestamp': item.timestamp}
- for item in pagination.items]
- return render_template('followers.html', user=user, title="Followers of",
- endpoint='.followers', pagination=pagination,
- follows=follows)
-
-
- @main.route('/followed-by/<username>')
- def followed_by(username):
- user = User.query.filter_by(username=username).first()
- if user is None:
- flash('Invalid user')
- return redirect(url_for('.index'))
- page = request.args.get('page', 1, type=int)
- pagination = user.followed.paginate(
- page, per_page=current_app.config['FLASKY_FOLLOWERS_PER_PAGE'],
- error_out=False)
- follows = [{'user': item.followed, 'timestamp': item.timestamp}
- for item in pagination.items]
- return render_template('followers.html', user=user, title="Followed by",
- endpoint='.followed_by', pagination=pagination,
- follows=follows)
-
-
- @main.route('/all')
- @login_required
- def show_all():
- resp = make_response(redirect(url_for('.index')))
- resp.set_cookie('show_followed', '', max_age=30*24*60*60) # lasts 30 days
- return resp
-
-
- @main.route('/followed')
- @login_required
- def show_followed():
- resp = make_response(redirect(url_for('.index')))
- resp.set_cookie('show_followed', '1', max_age=30*24*60*60) # lasts 30 days
- return resp
|