Mercurial > public > sg101
view gpp/downloads/management/commands/dlwgetcat.py @ 532:ff67946fd4b0
For #242, move the updating of the POTD sequence into a new signals module.
When photos are deleted from the admin changelist in bulk, the individual
delete() functions on the photo objects is not called. However, the post_delete
signal is called for each object.
author | Brian Neal <bgneal@gmail.com> |
---|---|
date | Sun, 25 Dec 2011 04:15:32 +0000 |
parents | 311c926dd218 |
children |
line wrap: on
line source
""" dlwgetcat - a management command to produce a bash script that wgets all the files in a given category. """ import os.path from django.core.management.base import LabelCommand, CommandError from django.template.loader import render_to_string from django.template.defaultfilters import slugify from django.contrib.sites.models import Site from django.conf import settings from downloads.models import Category, Download class Command(LabelCommand): help = ("Produce on standard output a bash script that wgets all the files" " in a category. The files are downloaded with a slugified name.") args = "category-slug" def handle_label(self, slug, **options): """ Render a template using the downloads in a given category and send it to stdout. """ try: category = Category.objects.get(slug=slug) except Category.DoesNotExist: raise CommandError("category slug '%s' does not exist" % slug) downloads = Download.public_objects.filter(category=category).order_by( 'title').select_related() # Create new destination names for the files since the uploaders often # give the files terrible names. The new names will be slugified # versions of the titles, with the same extension. for dl in downloads: ext = os.path.splitext(dl.file.name)[1] dl.dest_filename = slugify(dl.title) + ext output = render_to_string('downloads/commands/wget_cat.html', { 'downloads': downloads, 'domain': Site.objects.get_current().domain, 'MEDIA_URL': settings.MEDIA_URL, }) # encode it ourselves since it can fail if you try to redirect output to # a file and any of the content is not ASCII... print output.encode('utf-8')