2022-02-14 11:05:35 -05:00
|
|
|
from itertools import groupby
|
|
|
|
|
|
|
|
from django.core import mail
|
|
|
|
from django.core.mail.message import sanitize_address
|
|
|
|
from django.contrib.auth import get_user_model
|
|
|
|
from django.template import loader
|
|
|
|
|
|
|
|
from markdownify import markdownify
|
|
|
|
import mdformat
|
|
|
|
|
|
|
|
from membershipworks.models import Member
|
|
|
|
|
|
|
|
|
|
|
|
def make_multipart_email(subject, html_body, to):
|
|
|
|
plain_body = mdformat.text(markdownify(html_body), extensions={"tables"})
|
|
|
|
|
|
|
|
email = mail.EmailMultiAlternatives(
|
|
|
|
subject,
|
|
|
|
plain_body,
|
|
|
|
"Claremont MakerSpace Member Certification System <Certifications@ClaremontMakerSpace.org>",
|
|
|
|
to,
|
|
|
|
reply_to=["Claremont MakerSpace <Info@ClaremontMakerSpace.org>"],
|
|
|
|
)
|
|
|
|
|
|
|
|
email.attach_alternative(html_body, "text/html")
|
|
|
|
return email
|
|
|
|
|
|
|
|
|
|
|
|
def make_department_email(department, certifications):
|
2022-02-14 15:26:47 -05:00
|
|
|
template = loader.get_template("paperwork/email/department_certifications.dj.html")
|
2022-02-14 11:05:35 -05:00
|
|
|
shop_leads = Member.objects.filter(
|
|
|
|
flags__type="label", flags__name="Shop Lead: " + department
|
|
|
|
).values_list("first_name", "account_name", "email", named=True)
|
|
|
|
|
|
|
|
html_body = template.render(
|
|
|
|
{
|
|
|
|
"shop_lead_names": [shop_lead.first_name for shop_lead in shop_leads],
|
|
|
|
"department": department,
|
|
|
|
"certifications": certifications,
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
return make_multipart_email(
|
|
|
|
f"{len(certifications)} new CMS Certifications issued for {department}",
|
|
|
|
html_body,
|
|
|
|
to=[
|
|
|
|
sanitize_address((shop_lead.account_name, shop_lead.email), "ascii")
|
|
|
|
for shop_lead in shop_leads
|
|
|
|
],
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def department_emails(ordered_queryset):
|
|
|
|
certifications_by_department = groupby(
|
|
|
|
ordered_queryset, lambda c: c.certification_version.definition.department
|
|
|
|
)
|
|
|
|
|
|
|
|
for department, certifications in certifications_by_department:
|
|
|
|
yield make_department_email(department, list(certifications))
|
|
|
|
|
|
|
|
|
|
|
|
def make_member_email(member, certifications):
|
2022-02-14 15:26:47 -05:00
|
|
|
template = loader.get_template("paperwork/email/member_certifications.dj.html")
|
2022-02-14 11:05:35 -05:00
|
|
|
|
|
|
|
html_body = template.render({"member": member, "certifications": certifications})
|
|
|
|
|
|
|
|
return make_multipart_email(
|
|
|
|
f"You have been issued {len(certifications)} new CMS Certifications",
|
|
|
|
html_body,
|
|
|
|
to=[sanitize_address((member.account_name, member.email), "ascii")],
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def member_emails(ordered_queryset):
|
|
|
|
certifications_by_member = groupby(
|
|
|
|
ordered_queryset.filter(member__isnull=False), lambda c: c.member
|
|
|
|
)
|
|
|
|
|
|
|
|
for member, certifications in certifications_by_member:
|
|
|
|
yield make_member_email(member, list(certifications))
|
|
|
|
|
|
|
|
|
|
|
|
def admin_email(ordered_queryset):
|
2022-02-14 15:26:47 -05:00
|
|
|
template = loader.get_template("paperwork/email/admin_certifications.dj.html")
|
2022-02-14 11:05:35 -05:00
|
|
|
html_body = template.render({"certifications": ordered_queryset})
|
|
|
|
|
|
|
|
return make_multipart_email(
|
|
|
|
f"{len(ordered_queryset)} new CMS Certifications issued",
|
|
|
|
html_body,
|
|
|
|
# TODO: Admin emails should probably be from a group, not all staff
|
2022-02-24 21:59:16 -05:00
|
|
|
to=(
|
|
|
|
get_user_model()
|
|
|
|
.objects.filter(is_staff=True)
|
|
|
|
.values_list("email", flat=True)
|
|
|
|
),
|
2022-02-14 11:05:35 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
def all_certification_emails(queryset):
|
|
|
|
ordered_queryset = queryset.select_related(
|
|
|
|
"certification_version__definition"
|
|
|
|
).order_by("certification_version__definition__department")
|
|
|
|
|
|
|
|
yield from department_emails(ordered_queryset)
|
|
|
|
yield from member_emails(ordered_queryset)
|
|
|
|
yield admin_email(ordered_queryset)
|