Only send a maximum of 20 interest emails
This commit is contained in:
parent
32585495be
commit
5f302a0de7
|
@ -314,11 +314,12 @@ class SessionViewSet(Base, List, Retrieve, Create, Update):
|
||||||
logging.info('Session is in the past or too soon, not sending interest emails.')
|
logging.info('Session is in the past or too soon, not sending interest emails.')
|
||||||
return
|
return
|
||||||
|
|
||||||
|
with transaction.atomic():
|
||||||
interests = models.Interest.objects.filter(
|
interests = models.Interest.objects.filter(
|
||||||
course=session.course,
|
course=session.course,
|
||||||
satisfied_by__isnull=True,
|
satisfied_by__isnull=True,
|
||||||
user__member__paused_date__isnull=True
|
user__member__paused_date__isnull=True
|
||||||
)
|
)[:20]
|
||||||
|
|
||||||
for num, interest in enumerate(interests):
|
for num, interest in enumerate(interests):
|
||||||
msg = 'Sending email {} / {}...'.format(num+1, len(interests))
|
msg = 'Sending email {} / {}...'.format(num+1, len(interests))
|
||||||
|
@ -331,7 +332,9 @@ class SessionViewSet(Base, List, Retrieve, Create, Update):
|
||||||
logger.exception(msg)
|
logger.exception(msg)
|
||||||
utils.alert_tanner(msg)
|
utils.alert_tanner(msg)
|
||||||
|
|
||||||
num_satisfied = interests.update(satisfied_by=session)
|
interest_ids = interests.values('id')
|
||||||
|
num_satisfied = models.Interest.objects.filter(id__in=interest_ids).update(satisfied_by=session)
|
||||||
|
|
||||||
logging.info('Satisfied %s interests.', num_satisfied)
|
logging.info('Satisfied %s interests.', num_satisfied)
|
||||||
|
|
||||||
def generate_ical(self, session):
|
def generate_ical(self, session):
|
||||||
|
|
Loading…
Reference in New Issue
Block a user