summaryrefslogtreecommitdiff
path: root/yaksh/models.py
diff options
context:
space:
mode:
authoradityacp2018-06-26 16:03:10 +0530
committeradityacp2018-06-26 16:03:10 +0530
commitddd2981529798b8c59dec33e50ccf6e808f3bc19 (patch)
tree946b2bf9b4eee1c82188cd438e3342e2fb2cc900 /yaksh/models.py
parenta200623e1739cb85c5125b0c5115663489e51633 (diff)
downloadonline_test-ddd2981529798b8c59dec33e50ccf6e808f3bc19.tar.gz
online_test-ddd2981529798b8c59dec33e50ccf6e808f3bc19.tar.bz2
online_test-ddd2981529798b8c59dec33e50ccf6e808f3bc19.zip
Fix course download to support Python 2 and 3
Diffstat (limited to 'yaksh/models.py')
-rw-r--r--yaksh/models.py29
1 files changed, 16 insertions, 13 deletions
diff --git a/yaksh/models.py b/yaksh/models.py
index b97859d..34aee25 100644
--- a/yaksh/models.py
+++ b/yaksh/models.py
@@ -210,12 +210,12 @@ class Lesson(models.Model):
if self.video_file:
video_file = os.sep.join((sub_folder_name, os.path.basename(
self.video_file.name)))
- zip_file.write(self.video_file.path, video_file)
+ zip_file.writestr(video_file, self.video_file.read())
for lesson_file in lesson_files:
if os.path.exists(lesson_file.file.path):
filename = os.sep.join((sub_folder_name, os.path.basename(
lesson_file.file.name)))
- zip_file.write(lesson_file.file.path, filename)
+ zip_file.writestr(filename, lesson_file.file.read())
unit_file_path = os.sep.join((
path, "templates", "yaksh", "unit.html"
))
@@ -228,7 +228,7 @@ class Lesson(models.Model):
#############################################################################
class LessonFile(models.Model):
lesson = models.ForeignKey(Lesson, related_name="lesson")
- file = models.FileField(upload_to=get_file_dir)
+ file = models.FileField(upload_to=get_file_dir, default=None)
def remove(self):
if os.path.exists(self.file.path):
@@ -882,16 +882,19 @@ class Course(models.Model):
def is_student(self, user):
return user in self.students.all()
- def create_zip(self, zip_file, path):
- course_name = self.name.replace(" ", "_")
- modules = self.get_learning_modules()
- file_path = os.sep.join((path, "templates", "yaksh", "index.html"))
- write_static_files_to_zip(zip_file, course_name, path)
- course_data = {"course": self, "modules": modules}
- write_templates_to_zip(zip_file, file_path, course_data,
- "index", course_name)
- for module in modules:
- module._add_module_to_zip(self, zip_file, path)
+ def create_zip(self, path):
+ zip_file_name = string_io()
+ with zipfile.ZipFile(zip_file_name, "a") as zip_file:
+ course_name = self.name.replace(" ", "_")
+ modules = self.get_learning_modules()
+ file_path = os.sep.join((path, "templates", "yaksh", "index.html"))
+ write_static_files_to_zip(zip_file, course_name, path)
+ course_data = {"course": self, "modules": modules}
+ write_templates_to_zip(zip_file, file_path, course_data,
+ "index", course_name)
+ for module in modules:
+ module._add_module_to_zip(self, zip_file, path)
+ return zip_file_name
def has_lessons(self):
modules = self.get_learning_modules()