diff options
author | RaNaN <Mast3rRaNaN@hotmail.de> | 2010-08-20 22:04:37 +0200 |
---|---|---|
committer | RaNaN <Mast3rRaNaN@hotmail.de> | 2010-08-20 22:04:37 +0200 |
commit | 446df9c1468d72ec1456dd7d44dd8ceefaa4c0ad (patch) | |
tree | 38b00be2d62f375d7a9f633328de2573b6cc92af /module/web/createsuperuser.py | |
parent | debug report + deposit fix (diff) | |
download | pyload-446df9c1468d72ec1456dd7d44dd8ceefaa4c0ad.tar.xz |
setup improvements, UnRar fix
Diffstat (limited to 'module/web/createsuperuser.py')
-rw-r--r-- | module/web/createsuperuser.py | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/module/web/createsuperuser.py b/module/web/createsuperuser.py new file mode 100644 index 000000000..892069f84 --- /dev/null +++ b/module/web/createsuperuser.py @@ -0,0 +1,43 @@ +""" +Management utility to create superusers. +""" + +import os +import sys + +os.environ["DJANGO_SETTINGS_MODULE"] = 'settings' + + +import getpass +import re +from optparse import make_option +from django.contrib.auth.models import User +from django.core import exceptions +from django.core.management.base import BaseCommand, CommandError +from django.utils.translation import ugettext as _ + +RE_VALID_USERNAME = re.compile('[\w.@+-]+$') + + +def handle(username, email): + #username = options.get('username', None) + #email = options.get('email', None) + interactive = False + + # Do quick and dirty validation if --noinput + if not interactive: + if not username or not email: + raise CommandError("You must use --username and --email with --noinput.") + if not RE_VALID_USERNAME.match(username): + raise CommandError("Invalid username. Use only letters, digits, and underscores") + + password = '' + default_username = '' + + User.objects.create_superuser(username, email, password) + print "Superuser created successfully." + +if __name__ == "__main__": + username = sys.argv[1] + email = sys.argv[2] + handle(username, email)
\ No newline at end of file |