You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

73 lines
2.7 KiB

  1. from flask import render_template, redirect, url_for, flash
  2. from flask_login import login_required, current_user
  3. from . import main
  4. from .forms import EditProfileForm, EditProfileAdminForm, PostForm
  5. from .. import db
  6. from ..models import User, Role, Permission, Post
  7. from ..decorators import admin_required
  8. @main.route('/', methods=['GET', 'POST'])
  9. def index():
  10. form = PostForm()
  11. if current_user.can(Permission.WRITE) and form.validate_on_submit():
  12. post = Post(body=form.body.data,
  13. author=current_user._get_current_object())
  14. db.session.add(post)
  15. db.session.commit()
  16. return redirect(url_for('.index'))
  17. posts = Post.query.order_by(Post.timestamp.desc()).all()
  18. return render_template('index.html', form=form, posts=posts)
  19. @main.route('/user/<username>')
  20. def user(username):
  21. user = User.query.filter_by(username=username).first_or_404()
  22. posts = user.posts.order_by(Post.timestamp.desc()).all()
  23. return render_template('user.html', user=user, posts=posts)
  24. @main.route('/edit-profile', methods=['GET', 'POST'])
  25. @login_required
  26. def edit_profile():
  27. form = EditProfileForm()
  28. if form.validate_on_submit():
  29. current_user.name = form.name.data
  30. current_user.location = form.location.data
  31. current_user.about_me = form.about_me.data
  32. db.session.add(current_user._get_current_object())
  33. db.session.commit()
  34. flash('Your profile has been updated.')
  35. return redirect(url_for('.user', username=current_user.username))
  36. form.name.data = current_user.name
  37. form.location.data = current_user.location
  38. form.about_me.data = current_user.about_me
  39. return render_template('edit_profile.html', form=form)
  40. @main.route('/edit-profile/<int:id>', methods=['GET', 'POST'])
  41. @login_required
  42. @admin_required
  43. def edit_profile_admin(id):
  44. user = User.query.get_or_404(id)
  45. form = EditProfileAdminForm(user=user)
  46. if form.validate_on_submit():
  47. user.email = form.email.data
  48. user.username = form.username.data
  49. user.comfirmed = form.confirmed.data
  50. user.role = Role.query.get(form.role.data)
  51. user.name = form.name.data
  52. user.location = form.location.data
  53. user.about_me = form.about_me.data
  54. db.session.add(user)
  55. db.session.commit()
  56. flash('The profile has been updated.')
  57. return redirect(url_for('.user', username=user.username))
  58. form.email.data = user.email
  59. form.username.data = user.username
  60. form.confirmed.data = user.confirmed
  61. form.role.data = user.role_id
  62. form.name.data = user.name
  63. form.location.data = user.location
  64. form.about_me.data = user.about_me
  65. return render_template('edit_profile.html', form=form, user=user)