alias_log.py 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. import arrow
  2. from flask import render_template, flash, redirect, url_for
  3. from flask_login import login_required, current_user
  4. from app.dashboard.base import dashboard_bp
  5. from app.extensions import db
  6. from app.models import GenEmail, ForwardEmailLog, ForwardEmail
  7. _LIMIT = 15
  8. class AliasLog:
  9. website_email: str
  10. website_from: str
  11. alias: str
  12. when: arrow.Arrow
  13. is_reply: bool
  14. blocked: bool
  15. def __init__(self, **kwargs):
  16. for k, v in kwargs.items():
  17. setattr(self, k, v)
  18. @dashboard_bp.route(
  19. "/alias_log/<int:alias_id>", methods=["GET"], defaults={"page_id": 0}
  20. )
  21. @dashboard_bp.route("/alias_log/<int:alias_id>/<int:page_id>")
  22. @login_required
  23. def alias_log(alias_id, page_id):
  24. gen_email = GenEmail.get(alias_id)
  25. # sanity check
  26. if not gen_email:
  27. flash("You do not have access to this page", "warning")
  28. return redirect(url_for("dashboard.index"))
  29. if gen_email.user_id != current_user.id:
  30. flash("You do not have access to this page", "warning")
  31. return redirect(url_for("dashboard.index"))
  32. logs = get_alias_log(gen_email, page_id)
  33. base = (
  34. db.session.query(ForwardEmail, ForwardEmailLog)
  35. .filter(ForwardEmail.id == ForwardEmailLog.forward_id)
  36. .filter(ForwardEmail.gen_email_id == gen_email.id)
  37. )
  38. total = base.count()
  39. email_forwarded = (
  40. base.filter(ForwardEmailLog.is_reply == False)
  41. .filter(ForwardEmailLog.blocked == False)
  42. .count()
  43. )
  44. email_replied = base.filter(ForwardEmailLog.is_reply == True).count()
  45. email_blocked = base.filter(ForwardEmailLog.blocked == True).count()
  46. last_page = (
  47. len(logs) < _LIMIT
  48. ) # lightweight pagination without counting all objects
  49. return render_template("dashboard/alias_log.html", **locals())
  50. def get_alias_log(gen_email: GenEmail, page_id=0):
  51. logs: [AliasLog] = []
  52. q = (
  53. db.session.query(ForwardEmail, ForwardEmailLog)
  54. .filter(ForwardEmail.id == ForwardEmailLog.forward_id)
  55. .filter(ForwardEmail.gen_email_id == gen_email.id)
  56. .limit(_LIMIT)
  57. .offset(page_id * _LIMIT)
  58. )
  59. for fe, fel in q:
  60. al = AliasLog(
  61. website_email=fe.website_email,
  62. website_from=fe.website_from,
  63. alias=gen_email.email,
  64. when=fel.created_at,
  65. is_reply=fel.is_reply,
  66. blocked=fel.blocked,
  67. )
  68. logs.append(al)
  69. logs = sorted(logs, key=lambda l: l.when, reverse=True)
  70. return logs