Files @ 33305d27ac85
Branch filter:

Location: symposion_app/vendor/symposion/sponsorship/management/commands/export_sponsors_data.py

bsturmfels
Can just live in /tmp instead
import csv
import os
import shutil
import zipfile

from contextlib import closing

from django.core.management.base import BaseCommand
from django.template.defaultfilters import slugify

from sotmjp.sponsorship.models import Sponsor


def zipdir(basedir, archivename):
    assert os.path.isdir(basedir)
    with closing(zipfile.ZipFile(archivename, "w", zipfile.ZIP_DEFLATED)) as z:
        for root, dirs, files in os.walk(basedir):
            #NOTE: ignore empty directories
            for fn in files:
                absfn = os.path.join(root, fn)
                zfn = absfn[len(basedir) + len(os.sep):]     # XXX: relative path
                z.write(absfn, zfn)


class Command(BaseCommand):

    def handle(self, *args, **options):
        try:
            os.makedirs(os.path.join(os.getcwd(), "build"))
        except:
            pass

        with open(os.path.join(os.getcwd(), "build", "sponsors.csv"), "w") as csv_file:
            csv_writer = csv.writer(csv_file)
            csv_writer.writerow(["Name", "URL", "Level", "Description"])

            for sponsor in Sponsor.objects.all():
                path = os.path.join(os.getcwd(), "build", slugify(sponsor.name))
                try:
                    os.makedirs(path)
                except:
                    pass

                data = {
                    "name": sponsor.name,
                    "url": sponsor.external_url,
                    "level": sponsor.level.name,
                    "description": "",
                }

                for sponsor_benefit in sponsor.sponsor_benefits.all():
                    if sponsor_benefit.benefit_id == 2:
                        data["description"] = sponsor_benefit.text
                    if sponsor_benefit.benefit_id == 1:
                        if sponsor_benefit.upload:
                            data["ad"] = sponsor_benefit.upload.path
                    if sponsor_benefit.benefit_id == 7:
                        if sponsor_benefit.upload:
                            data["logo"] = sponsor_benefit.upload.path

                if "ad" in data:
                    ad_path = data.pop("ad")
                    shutil.copy(ad_path, path)
                if "logo" in data:
                    logo_path = data.pop("logo")
                    shutil.copy(logo_path, path)

                csv_writer.writerow([
                    data["name"],
                    data["url"],
                    data["level"],
                    data["description"]
                ])

            zipdir(
                os.path.join(os.getcwd(), "build"),
                os.path.join(os.getcwd(), "sponsors.zip"))