Skip to content

Commit

Permalink
Merge pull request #22 from s-aga-r/report-delivery-error
Browse files Browse the repository at this point in the history
feat: report `Outgoing Mail Summary`
  • Loading branch information
s-aga-r authored Oct 18, 2024
2 parents 939773e + 5c04f91 commit c8e55da
Show file tree
Hide file tree
Showing 6 changed files with 619 additions and 225 deletions.
183 changes: 91 additions & 92 deletions mail/mail/report/mail_tracker/mail_tracker.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,111 +3,21 @@

import frappe
from frappe import _
from typing import Tuple
from frappe.query_builder.functions import Date
from frappe.query_builder import Order, Criterion
from mail.utils.cache import get_user_owned_domains
from mail.utils.user import has_role, is_system_manager, get_user_mailboxes


def execute(filters=None) -> Tuple[list, list]:
def execute(filters: dict | None = None) -> tuple:
columns = get_columns()
data = get_data(filters)
summary = get_summary(data)

return columns, data, None, None, summary


def get_data(filters=None) -> list:
filters = filters or {}

OM = frappe.qb.DocType("Outgoing Mail")
query = (
frappe.qb.from_(OM)
.select(
OM.name,
OM.creation,
OM.status,
OM.open_count,
OM.agent,
OM.domain_name,
OM.sender,
OM.message_id,
OM.tracking_id,
OM.created_at,
OM.first_opened_at,
OM.last_opened_at,
OM.last_opened_from_ip,
)
.where((OM.docstatus == 1) & (OM.tracking_id.isnotnull()))
.orderby(OM.creation, OM.created_at, order=Order.desc)
)

if (
not filters.get("name")
and not filters.get("message_id")
and not filters.get("tracking_id")
):
query = query.where(
(Date(OM.created_at) >= Date(filters.get("from_date")))
& (Date(OM.created_at) <= Date(filters.get("to_date")))
)

for field in [
"name",
"status",
"agent",
"domain_name",
"sender",
"message_id",
"tracking_id",
]:
if filters.get(field):
query = query.where(OM[field] == filters.get(field))

user = frappe.session.user
if not is_system_manager(user):
conditions = []
domains = get_user_owned_domains(user)
mailboxes = get_user_mailboxes(user)

if has_role(user, "Domain Owner") and domains:
conditions.append(OM.domain_name.isin(domains))

if has_role(user, "Mailbox User") and mailboxes:
conditions.append(OM.sender.isin(mailboxes))

if not conditions:
return []

query = query.where(Criterion.any(conditions))

return query.run(as_dict=True)


def get_summary(data: dict) -> list[dict]:
total_open_count = 0
for row in data:
if row["open_count"] > 0:
total_open_count += 1

return [
{
"value": len(data),
"indicator": "green",
"label": "Total Sent",
"datatype": "Int",
},
{
"value": total_open_count,
"indicator": "blue",
"label": "Total Opened",
"datatype": "Int",
},
]


def get_columns() -> list:
def get_columns() -> list[dict]:
return [
{
"label": _("Name"),
Expand Down Expand Up @@ -191,3 +101,92 @@ def get_columns() -> list:
"width": 120,
},
]


def get_data(filters: dict | None = None) -> list[list]:
filters = filters or {}

OM = frappe.qb.DocType("Outgoing Mail")
query = (
frappe.qb.from_(OM)
.select(
OM.name,
OM.creation,
OM.status,
OM.open_count,
OM.agent,
OM.domain_name,
OM.sender,
OM.message_id,
OM.tracking_id,
OM.created_at,
OM.first_opened_at,
OM.last_opened_at,
OM.last_opened_from_ip,
)
.where((OM.docstatus == 1) & (OM.tracking_id.isnotnull()))
.orderby(OM.creation, OM.created_at, order=Order.desc)
)

if (
not filters.get("name")
and not filters.get("message_id")
and not filters.get("tracking_id")
):
query = query.where(
(Date(OM.created_at) >= Date(filters.get("from_date")))
& (Date(OM.created_at) <= Date(filters.get("to_date")))
)

for field in [
"name",
"status",
"agent",
"domain_name",
"sender",
"message_id",
"tracking_id",
]:
if filters.get(field):
query = query.where(OM[field] == filters.get(field))

user = frappe.session.user
if not is_system_manager(user):
conditions = []
domains = get_user_owned_domains(user)
mailboxes = get_user_mailboxes(user)

if has_role(user, "Domain Owner") and domains:
conditions.append(OM.domain_name.isin(domains))

if has_role(user, "Mailbox User") and mailboxes:
conditions.append(OM.sender.isin(mailboxes))

if not conditions:
return []

query = query.where(Criterion.any(conditions))

return query.run(as_dict=True)


def get_summary(data: dict) -> list[dict]:
total_open_count = 0
for row in data:
if row["open_count"] > 0:
total_open_count += 1

return [
{
"label": _("Total Sent"),
"datatype": "Int",
"value": len(data),
"indicator": "green",
},
{
"label": _("Total Opened"),
"datatype": "Int",
"value": total_open_count,
"indicator": "blue",
},
]
Loading

0 comments on commit c8e55da

Please sign in to comment.