alias_log.py 2.6 KB

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