X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/7fb4da9ecca0993ce6d61750739690ab680cab30..eb1b2a97a14f9a4daa772709972e0d1650ac4fd3:/forum/management/commands/send_email_alerts.py?ds=sidebyside diff --git a/forum/management/commands/send_email_alerts.py b/forum/management/commands/send_email_alerts.py index 4cdb2e1..80159e7 100644 --- a/forum/management/commands/send_email_alerts.py +++ b/forum/management/commands/send_email_alerts.py @@ -1,9 +1,10 @@ import datetime from forum.models import * +from forum import settings from django.db import models from forum.utils.mail import send_template_email from django.core.management.base import NoArgsCommand -from forum.settings.email import EMAIL_DIGEST_CONTROL +from forum.settings.email import EMAIL_DIGEST_FLAG from django.utils import translation import logging @@ -11,8 +12,6 @@ SHOW_N_MORE_ACTIVE_NEW_MEMBERS = 5 SUB_QUESTION_LIST_LENGTH = 5 TRY_N_USER_TAGS = 5 - - class DigestQuestionsIndex(object): def __init__(self, from_date): self.from_date = from_date @@ -79,24 +78,27 @@ class Command(NoArgsCommand): except: logging.error("Unable to set the locale in the send emails cron job") - digest_control = EMAIL_DIGEST_CONTROL.value + digest_control = EMAIL_DIGEST_FLAG.value if digest_control is None: - digest_control = KeyValue(key='DIGEST_CONTROL', value={ + digest_control = { 'LAST_DAILY': datetime.datetime.now() - datetime.timedelta(days=1), 'LAST_WEEKLY': datetime.datetime.now() - datetime.timedelta(days=1), - }) + } - from_date = digest_control.value['LAST_DAILY'] - digest_control.value['LAST_DAILY'] = datetime.datetime.now() + from_date = digest_control['LAST_DAILY'] + digest_control['LAST_DAILY'] = datetime.datetime.now() - EMAIL_DIGEST_CONTROL.set_value(digest_control) + EMAIL_DIGEST_FLAG.set_value(digest_control) - users = User.objects.filter(subscription_settings__enable_notifications=True) + users = User.objects.filter(subscription_settings__enable_notifications=True, subscription_settings__send_digest=True) new_members = User.objects.filter(is_active=True, date_joined__gt=from_date).annotate(n_actions=models.Count('actions')).order_by('-n_actions') new_member_count = new_members.count() + # The number of the flagged content for the day + flagged_count = Flag.objects.filter(flagged_at__gt=datetime.datetime.today()-datetime.timedelta(days=1)).count() + if new_member_count >= SHOW_N_MORE_ACTIVE_NEW_MEMBERS: new_members = new_members[:SHOW_N_MORE_ACTIVE_NEW_MEMBERS] show_all_users = True @@ -105,6 +107,9 @@ class Command(NoArgsCommand): digest = DigestQuestionsIndex(from_date) + if (not new_member_count) and (not digest.count): + return + send_template_email(users, "notifications/digest.html", locals())