from django.core.management.base import BaseCommand, CommandError
import os
from optparse import make_option
from student.models import UserProfile
import csv


class Command(BaseCommand):

    help = """
    Sets or gets certificate restrictions for users
    from embargoed countries. (allow_certificate in
    userprofile)

    CSV should be comma delimited with double quoted entries.

        $ ... cert_restriction --import path/to/userlist.csv

    Export a list of students who have "allow_certificate" in
    userprofile set to True

        $ ... cert_restriction --output path/to/export.csv

    Enable a single user so she is not on the restricted list

        $ ... cert_restriction -e user

    Disable a single user so she is on the restricted list

        $ ... cert_restriction -d user

    """

    option_list = BaseCommand.option_list + (
        make_option('-i', '--import',
                    metavar='IMPORT_FILE',
                    dest='import',
                    default=False,
                    help='csv file to import, comma delimitted file with '
                         'double-quoted entries'),
        make_option('-o', '--output',
                    metavar='EXPORT_FILE',
                    dest='output',
                    default=False,
                    help='csv file to export'),
        make_option('-e', '--enable',
                    metavar='STUDENT',
                    dest='enable',
                    default=False,
                    help="enable a single student's certificate"),
        make_option('-d', '--disable',
                    metavar='STUDENT',
                    dest='disable',
                    default=False,
                    help="disable a single student's certificate")
    )

    def handle(self, *args, **options):
        if options['output']:

            if os.path.exists(options['output']):
                raise CommandError("File {0} already exists".format(
                    options['output']))
            disabled_users = UserProfile.objects.filter(
                allow_certificate=False)

            with open(options['output'], 'w') as csvfile:
                csvwriter = csv.writer(csvfile, delimiter=',', quotechar='"',
                                       quoting=csv.QUOTE_MINIMAL)
                for user in disabled_users:
                    csvwriter.writerow([user.user.username])

        elif options['import']:

            if not os.path.exists(options['import']):
                raise CommandError("File {0} does not exist".format(
                    options['import']))

            print "Importing students from {0}".format(options['import'])

            students = None
            with open(options['import']) as csvfile:
                student_list = csv.reader(csvfile, delimiter=',',
                                          quotechar='"')
                students = [student[0] for student in student_list]
            if not students:
                raise CommandError(
                    "Unable to read student data from {0}".format(
                        options['import']))
            UserProfile.objects.filter(user__username__in=students).update(
                allow_certificate=False)

        elif options['enable']:

            print "Enabling {0} for certificate download".format(
                options['enable'])
            cert_allow = UserProfile.objects.get(
                user__username=options['enable'])
            cert_allow.allow_certificate = True
            cert_allow.save()

        elif options['disable']:

            print "Disabling {0} for certificate download".format(
                options['disable'])
            cert_allow = UserProfile.objects.get(
                user__username=options['disable'])
            cert_allow.allow_certificate = False
            cert_allow.save()