Files
zulip/zephyr/management/commands/change_user_email.py
Tim Abbott 198480ef99 Use get_user_profile_by_email more consistently.
The previous situation was bad for two reasons:

(1) It had a lot of copies of the code, some of them missing pieces:
  UserProfile.objects.get(user__email__iexact=foo)

This was in particular going to be inconvenient since we are dropping
the __user part of that.

(2) It didn't take advantage of our memcached caching.

(imported from commit 2325795f288a7cf306cdae191f5d3080aac0651a)
2013-03-29 16:18:38 -04:00

24 lines
763 B
Python

from django.core.management.base import BaseCommand
from zephyr.lib.actions import do_change_user_email
from zephyr.models import UserProfile, get_user_profile_by_email
class Command(BaseCommand):
help = """Change the email address for a user.
Usage: python manage.py change_user_email <old email> <new email>"""
def handle(self, *args, **options):
if len(args) != 2:
print "Please provide both the old and new address."
exit(1)
old_email, new_email = args
try:
user_profile = get_user_profile_by_email(old_email)
except UserProfile.DoesNotExist:
print "Old e-mail doesn't exist in the system."
exit(1)
do_change_user_email(user_profile, new_email)