-
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathsend_assignment_reminder_command.py
More file actions
78 lines (68 loc) · 3.06 KB
/
send_assignment_reminder_command.py
File metadata and controls
78 lines (68 loc) · 3.06 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
from django_email_learning.services.command_models.abstract_command import (
AbstractCommand,
)
from django_email_learning.models import ContentDelivery, DeliverySchedule
from django_email_learning.services.email_sender_service import EmailSenderService
from django_email_learning.services.metrics_service import MetricsService
from django.core.mail import EmailMultiAlternatives
from django.template.loader import render_to_string
from typing import Literal
from pydantic import ConfigDict
from django.utils.translation import gettext as _
from django.utils import timezone
from django_email_learning.services.utils import mask_email
class AssignmentNotFoundError(Exception):
pass
class SendAssignmentReminderCommand(AbstractCommand):
command_name: Literal["send_assignment_reminder"] = "send_assignment_reminder"
delivery_schedule: DeliverySchedule
model_config = ConfigDict(arbitrary_types_allowed=True)
def execute(self) -> None:
metric_service = MetricsService()
content = self.delivery_schedule.delivery.course_content
if not content.assignment:
raise AssignmentNotFoundError(
f"CourseContent with ID {content.id} has no associated assignment"
)
email = self.delivery_schedule.delivery.enrollment.learner.email
self.logger.info(
f"Sending reminder for assignment with ID {content.assignment.id} to email {mask_email(email)}"
)
assignment = content.assignment
subject = _("Reminder: Assignment '{assignment_title}' is due soon").format(
assignment_title=assignment.title
)
context = {
"assignment": assignment,
"link": self.delivery_schedule.link,
"unsubscribe_link": content.course.generate_unsubscribe_link(email),
"deadline_time": self.delivery_schedule.delivery.valid_until,
}
payload = render_to_string("emails/assignment_reminder.txt", context)
email_service = EmailSenderService()
email_message = EmailMultiAlternatives(
subject=subject,
body=payload,
from_email=email_service.from_email,
to=[email],
)
email_message.attach_alternative(
render_to_string("emails/assignment_reminder.html", context), "text/html"
)
try:
email_service.send(email_message)
self.delivery_schedule.delivery.remind_at = timezone.now()
self.delivery_schedule.delivery.reminder_state = (
ContentDelivery.ReminderStatus.SENT
)
self.delivery_schedule.delivery.save()
metric_service.assignment_reminder_sent(
course_slug=content.course.slug,
organization_id=content.course.organization.id,
assignment_id=assignment.id,
)
except Exception as e:
self.logger.error(
f"Failed to send assignment reminder for assignment with ID {assignment.id} to email {mask_email(email)}: {str(e)}"
)
raise e