msg.py 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  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. MsgApp.print_user_opt_fail_log(f"Load msg list with error page({page})")
  24. abort(404)
  25. return
  26. msg_list = load_message_list(20, (page - 1) * 20,
  27. show_secret=current_user.check_role("ReadSecretMsg")) # 判断是否可读取私密内容
  28. max_page = App.get_max_page(Message.get_msg_count(), 20)
  29. page_list = App.get_page("docx.docx_page", page, max_page)
  30. MsgApp.print_load_page_log(f"msg (page: {page})")
  31. return render_template("msg/msg.html",
  32. msg_list=msg_list,
  33. page_list=page_list,
  34. form=WriteForm(),
  35. is_secret=DBBit.BIT_1,
  36. show_delete=current_user.check_role("DeleteMsg"),
  37. show_email=current_user.check_role("ReadUserInfo"))
  38. @msg.route('/write', methods=["POST"])
  39. @login_required
  40. def write_msg_page():
  41. form = WriteForm()
  42. if form.validate_on_submit():
  43. auth: User = current_user
  44. if not auth.check_role("WriteMsg"): # 检查相应权限
  45. MsgApp.print_user_not_allow_opt_log("write msg")
  46. abort(403)
  47. return
  48. context = form.context.data
  49. secret = form.secret.data
  50. if Message(None, auth, context, secret, None).create():
  51. MsgApp.print_user_opt_success_log("write msg")
  52. flash("留言成功")
  53. else:
  54. MsgApp.print_user_opt_fail_log("write msg")
  55. flash("留言失败")
  56. return redirect(url_for("msg.msg_page", page=1))
  57. abort(404)
  58. @msg.route('/delete/<int:msg_id>')
  59. @login_required
  60. def delete_msg_page(msg_id: int):
  61. if not current_user.check_role("DeleteMsg"):
  62. MsgApp.print_user_not_allow_opt_log("delete msg")
  63. abort(403)
  64. return
  65. if Message(msg_id, None, None).delete():
  66. MsgApp.print_user_opt_success_log("delete msg")
  67. flash("留言删除成功")
  68. else:
  69. MsgApp.print_user_opt_fail_log("delete msg")
  70. flash("留言删除失败")
  71. return redirect(url_for("msg.msg_page", page=1))
  72. @msg.context_processor
  73. def inject_base():
  74. return {"top_nav": ["", "", "", "active", "", ""]}
  75. class MsgApp(App):
  76. def __init__(self, import_name):
  77. super(MsgApp, self).__init__(import_name)
  78. global app
  79. app = self._app
  80. app.register_blueprint(msg, url_prefix="/msg")