Browse Source

Merge pull request #180 from lucasmndc/master

Adição de html no email
pull/181/head 3.0.94
Sesostris Vieira 5 months ago
committed by GitHub
parent
commit
ab1ff400aa
No known key found for this signature in database GPG Key ID: B5690EEEBB952194
  1. 25
      sigi/apps/utils/models.py

25
sigi/apps/utils/models.py

@ -12,6 +12,8 @@ from tinymce.models import HTMLField
from django.core.mail import send_mail from django.core.mail import send_mail
from django.conf import settings from django.conf import settings
from datetime import timedelta from datetime import timedelta
from docutils.core import publish_string
from django.utils.html import format_html
class SigiAlert(models.Model): class SigiAlert(models.Model):
@ -224,6 +226,12 @@ class JobSchedule(models.Model):
now = timezone.localtime() now = timezone.localtime()
# Converte o resultado para HTML usando docutils
try:
html_result = publish_string(self.resultado, writer_name="html")
except Exception as e:
html_result = f"<p>Erro ao converter o log para HTML: {str(e)}</p>"
if self.job.digest == "N": if self.job.digest == "N":
# Envia imediatamente sem acumular # Envia imediatamente sem acumular
send_mail( send_mail(
@ -232,7 +240,7 @@ class JobSchedule(models.Model):
from_email=settings.SERVER_EMAIL, from_email=settings.SERVER_EMAIL,
recipient_list=self.job.get_emails_list(), recipient_list=self.job.get_emails_list(),
fail_silently=True, fail_silently=True,
html_message=self.resultado, html_message=html_result.decode("utf-8"),
) )
self.job.last_digest = now self.job.last_digest = now
self.job.save() self.job.save()
@ -279,11 +287,24 @@ class JobSchedule(models.Model):
if job_schedules.exists(): if job_schedules.exists():
message_lines = [] message_lines = []
html_message_lines = []
for js in job_schedules: for js in job_schedules:
message_lines.append( message_lines.append(
f"{localize(js.iniciado)}: {js.resultado}" f"{localize(js.iniciado)}: {js.resultado}"
) )
try:
html_message_lines.append(
publish_string(
js.resultado, writer_name="html"
).decode("utf-8")
)
except Exception as e:
html_message_lines.append(
f"<p>Erro ao converter o log para HTML: {str(e)}</p>"
)
message = "\n\n".join(message_lines) message = "\n\n".join(message_lines)
html_message = "<br><br>".join(html_message_lines)
send_mail( send_mail(
subject=f"Digest JOB: {self.job.job_name} ({frequency})", subject=f"Digest JOB: {self.job.job_name} ({frequency})",
@ -291,7 +312,7 @@ class JobSchedule(models.Model):
from_email=settings.SERVER_EMAIL, from_email=settings.SERVER_EMAIL,
recipient_list=self.job.get_emails_list(), recipient_list=self.job.get_emails_list(),
fail_silently=True, fail_silently=True,
html_message=message, html_message=html_message,
) )

Loading…
Cancel
Save