2024-02-22 17:37:31 +00:00
|
|
|
import logging
|
|
|
|
|
|
|
|
from urllib.parse import urlparse
|
|
|
|
|
|
|
|
from django.conf import settings
|
|
|
|
from django.template import loader
|
|
|
|
from django.core.mail import EmailMultiAlternatives
|
|
|
|
from django.core.management.base import BaseCommand
|
|
|
|
from django.contrib.auth import get_user_model
|
|
|
|
|
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
User = get_user_model()
|
|
|
|
|
|
|
|
|
|
|
|
class Command(BaseCommand):
|
|
|
|
help = "Send mails to the admins for add general key"
|
|
|
|
subject_template_name = 'idhub/admin/registration/start_app_admin_subject.txt'
|
|
|
|
email_template_name = 'idhub/admin/registration/start_app_admin_email.txt'
|
|
|
|
html_email_template_name = 'idhub/admin/registration/start_app_admin_email.html'
|
|
|
|
|
|
|
|
def handle(self, *args, **kwargs):
|
|
|
|
for user in User.objects.filter(is_admin=True):
|
|
|
|
self.send_email(user)
|
|
|
|
|
|
|
|
def send_email(self, user):
|
|
|
|
"""
|
|
|
|
Send a email when a user is activated.
|
|
|
|
"""
|
2024-03-04 08:44:53 +00:00
|
|
|
url_domain = f"https://{}/".format(settings.DOMAIN)
|
2024-02-22 17:37:31 +00:00
|
|
|
context = {
|
2024-03-04 08:44:53 +00:00
|
|
|
"domain": url_domain,
|
2024-02-22 17:37:31 +00:00
|
|
|
}
|
|
|
|
subject = loader.render_to_string(self.subject_template_name, context)
|
|
|
|
# Email subject *must not* contain newlines
|
|
|
|
subject = ''.join(subject.splitlines())
|
|
|
|
body = loader.render_to_string(self.email_template_name, context)
|
|
|
|
from_email = settings.DEFAULT_FROM_EMAIL
|
|
|
|
to_email = user.email
|
|
|
|
|
|
|
|
email_message = EmailMultiAlternatives(
|
|
|
|
subject, body, from_email, [to_email])
|
|
|
|
html_email = loader.render_to_string(self.html_email_template_name, context)
|
|
|
|
email_message.attach_alternative(html_email, 'text/html')
|
|
|
|
try:
|
|
|
|
if settings.ENABLE_EMAIL:
|
|
|
|
email_message.send()
|
|
|
|
return
|
|
|
|
|
|
|
|
logger.warning(to_email)
|
|
|
|
logger.warning(body)
|
|
|
|
|
|
|
|
except Exception as err:
|
|
|
|
logger.error(err)
|
|
|
|
return
|