Commit 624f417a authored by Stefano Rivera's avatar Stefano Rivera

Merge branch 'badger-speakers' into 'master'

Generalize badger speakers script

See merge request !29
parents 809e26c7 d125539d
import sys
from django.conf import settings
from django.contrib.auth.models import Group
from django.core.exceptions import ObjectDoesNotExist
from django.core.mail import EmailMultiAlternatives
from import BaseCommand
......@@ -8,8 +9,9 @@ from wafer.talks.models import Talk
FROM = ''
SUBJECT = '%(conference)s - talk accepted: %(title)s'
BODY = '''\
SUBJECT_A = '%(conference)s - talk accepted: %(title)s'
BODY_A = '''\
Dear speaker / BoF organizer,
We are glad to announce that your activity titled
......@@ -26,21 +28,79 @@ know by replying to this email, as soon as possible. Also, please cancel your
conference registration in the conference website.
Best regards,
The DebConf Content Team
The %(conference)s Content Team
SUBJECT_R = '%(conference)s - talk not accepted: %(title)s'
BODY_R = '''\
Dear submitter,
Thanks for your interest in %(conference)s.
We are sorry to say that your activity titled
was not accepted for presentation at the %(conference)s main schedule.
Note that %(conference)s will feature ad-hoc sessions where you can still
present your session. Those sessions are not covered by the video team, and so
not streamed or recorded. They are scheduled during the conference, so if you
are interested in presenting, come to %(conference)s, and and look out for an
email announcing the ad-hoc scheduling process.
We look forward to seeing you in %(city)s.
Best regards,
The %(conference)s Content Team
'A': {'subject': SUBJECT_A, 'body': BODY_A},
'R': {'subject': SUBJECT_R, 'body': BODY_R},
'accepted': 'A',
'not_accepted': 'R',
'under_consideration': 'U',
'provisionally_accepted': 'P',
class Command(BaseCommand):
help = "Notify speakers that their talks have been accepted"
help = "Notify speakers about their talks."
def add_arguments(self, parser):
parser.add_argument('--yes', action='store_true',
help='Actually do something'),
def badger(self, talk, dry_run):
parser.add_argument('--accepted', action='store_true',
help='Notify accepted talks'),
parser.add_argument('--not-accepted', action='store_true',
help='Notify rejected talks'),
parser.add_argument('--provisionally-accepted', action='store_true',
help='Notify provisionally accepted talks'),
parser.add_argument('--under-consideration', action='store_true',
help='Notify talks under consideration'),
parser.add_argument('--subject', type=str, metavar='SUBJECT',
help='String to use as subject template for the emails'),
parser.add_argument('--body', type=open, metavar='BODY',
help='File with template for the email body'),
parser.add_argument('--bcc', type=str, nargs='+',
help='Add each ADDR to Bcc:'),
def badger(self, talk, dry_run, subject_template, body_template, bcc):
status = talk.get_status_display().lower().replace(' ', '_')
kv, _ = talk.kv.get_or_create(
key='notified_speaker_' + status,
defaults={'value': None},
......@@ -55,14 +115,17 @@ class Command(BaseCommand):
'city': settings.DEBCONF_CITY,
subject = SUBJECT % subst
body = BODY % subst
subject = subject_template % subst
body = body_template % subst
if dry_run:
print('I would badger speakers of: %s' % talk.title)
print('I would badger speakers of: %s [status=%s]' % (talk.title,
print('Badgering speakers of: %s' % talk.title)
email_message = EmailMultiAlternatives(
subject, body, from_email=FROM, to=to)
subject, body, from_email=FROM, to=to, bcc=bcc)
kv.value = True
......@@ -75,5 +138,39 @@ class Command(BaseCommand):
if dry_run:
print('Not actually doing anything without --yes')
for talk in Talk.objects.filter(status='A'):
self.badger(talk, dry_run)
status = None
for key, value in OPTION_TO_STATUS.items():
if options[key]:
if status:
print('E: multiple talk statuses informed. Choose only one.')
status = value
if not status:
print("E: no talks selected; use --accepted, --not-accepted, etc")
if status not in TEMPLATES:
if not options['subject'] or not options['body']:
print('E: no built-in template for status "%s"; please provide one explicitly with --subject and --body' % status)
print('I: example subject template: %s' % TEMPLATES['A']['subject'])
print('I: example body template:')
if options['subject']:
subject_template = options['subject']
subject_template = TEMPLATES[status]['subject']
if options['body']:
body_template = options['body'].read()
body_template = TEMPLATES[status]['body']
bcc = options['bcc']
for talk in Talk.objects.filter(status=status):
self.badger(talk, dry_run, subject_template, body_template, bcc)
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment