1
0

msg.py 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. from flask import Flask, Blueprint, render_template, abort, redirect, url_for, flash
  2. from flask_wtf import FlaskForm
  3. from flask_login import login_required, current_user
  4. from wtforms import TextAreaField, BooleanField, SubmitField
  5. from wtforms.validators import DataRequired
  6. from typing import Optional
  7. from view.base import App
  8. from sql.base import DBBit
  9. from core.user import User
  10. from core.msg import Message, load_message_list
  11. msg = Blueprint("msg", __name__)
  12. app: Optional[Flask] = None
  13. class WriteForm(FlaskForm):
  14. """
  15. 写新内容表单
  16. """
  17. context = TextAreaField(validators=[DataRequired()])
  18. secret = BooleanField("私密留言")
  19. submit = SubmitField("留言")
  20. @msg.route('/<int:page>')
  21. def msg_page(page: int = 1):
  22. if page < 1:
  23. abort(404)
  24. return
  25. msg_list = load_message_list(20, (page - 1) * 20,
  26. show_secret=current_user.check_role("ReadSecretMsg")) # 判断是否可读取私密内容
  27. max_page = App.get_max_page(Message.get_msg_count(), 20)
  28. page_list = App.get_page("docx.docx_page", page, max_page)
  29. return render_template("msg/msg.html",
  30. msg_list=msg_list,
  31. page_list=page_list,
  32. form=WriteForm(),
  33. is_secret=DBBit.BIT_1,
  34. show_delete=current_user.check_role("DeleteMsg"),
  35. show_email=current_user.check_role("ReadUserInfo"))
  36. @msg.route('/write', methods=["POST"])
  37. @login_required
  38. def write_msg_page():
  39. form = WriteForm()
  40. if form.validate_on_submit():
  41. auth: User = current_user
  42. if not auth.check_role("WriteMsg"): # 检查相应权限
  43. abort(403)
  44. return
  45. context = form.context.data
  46. secret = form.secret.data
  47. if Message(None, auth, context, secret, None).create():
  48. flash("留言成功")
  49. else:
  50. flash("留言失败")
  51. return redirect(url_for("msg.msg_page", page=1))
  52. abort(404)
  53. @msg.route('/delete/<int:msg_id>')
  54. @login_required
  55. def delete_msg_page(msg_id: int):
  56. if not current_user.check_role("DeleteMsg"):
  57. abort(403)
  58. return
  59. if Message(msg_id, None, None).delete():
  60. flash("留言删除成功")
  61. else:
  62. flash("留言删除失败")
  63. return redirect(url_for("msg.msg_page", page=1))
  64. @msg.context_processor
  65. def inject_base():
  66. return {"top_nav": ["", "", "", "active", "", ""]}
  67. class MsgApp(App):
  68. def __init__(self, import_name):
  69. super(MsgApp, self).__init__(import_name)
  70. global app
  71. app = self._app
  72. app.register_blueprint(msg, url_prefix="/msg")