X-Git-Url: https://git.mdrn.pl/wolnelektury.git/blobdiff_plain/cf57591257968b71cd9b7b6e2745a0d23f0066e0..1fa5842d75ed72f9ed141d2283fbf1fab012ab92:/apps/catalogue/views.py diff --git a/apps/catalogue/views.py b/apps/catalogue/views.py index de75803a4..a2bd34f63 100644 --- a/apps/catalogue/views.py +++ b/apps/catalogue/views.py @@ -201,7 +201,7 @@ def book_sets(request, slug): context_instance=RequestContext(request)) -@cache.cache_control(must_revalidate=True, max_age=1800) +@cache.never_cache def download_shelf(request, slug): """" Create a ZIP archive on disk and transmit it in chunks of 8KB, @@ -209,20 +209,28 @@ def download_shelf(request, slug): be used for large dynamic PDF files. """ shelf = get_object_or_404(models.Tag, slug=slug, category='set') - + # Create a ZIP archive - temp = tempfile.TemporaryFile() - archive = zipfile.ZipFile(temp, 'w', zipfile.ZIP_DEFLATED) + temp = temp = tempfile.TemporaryFile() + archive = zipfile.ZipFile(temp, 'w') for book in models.Book.tagged.with_all(shelf): - filename = book.html_file.path - archive.write(filename, str('%s.html' % book.slug)) + if book.pdf_file: + filename = book.pdf_file.path + archive.write(filename, str('%s.pdf' % book.slug)) + if book.odt_file: + filename = book.odt_file.path + archive.write(filename, str('%s.odt' % book.slug)) + if book.txt_file: + filename = book.txt_file.path + archive.write(filename, str('%s.txt' % book.slug)) archive.close() - wrapper = FileWrapper(temp) - response = HttpResponse(wrapper, content_type='application/zip') - response['Content-Disposition'] = 'attachment; filename=%s.zip' % shelf.slug + response = HttpResponse(content_type='application/zip', mimetype='application/x-zip-compressed') + response['Content-Disposition'] = 'attachment; filename=%s.zip' % shelf.sort_key response['Content-Length'] = temp.tell() + temp.seek(0) + response.write(temp.read()) return response