summaryrefslogtreecommitdiff
path: root/yaksh/models.py
diff options
context:
space:
mode:
authorCruiseDevice2020-04-13 16:45:42 +0530
committerCruiseDevice2020-04-13 16:45:42 +0530
commit0e6c7d589114450d5cd1bc581ee1692c235f1a73 (patch)
tree3e1749b9695a708ac65deb5953d4913250335522 /yaksh/models.py
parent2a9f81cb32acfd7a2efc18f58c4529b39ce4061b (diff)
downloadonline_test-0e6c7d589114450d5cd1bc581ee1692c235f1a73.tar.gz
online_test-0e6c7d589114450d5cd1bc581ee1692c235f1a73.tar.bz2
online_test-0e6c7d589114450d5cd1bc581ee1692c235f1a73.zip
Add feature for uploading images
Diffstat (limited to 'yaksh/models.py')
-rw-r--r--yaksh/models.py46
1 files changed, 28 insertions, 18 deletions
diff --git a/yaksh/models.py b/yaksh/models.py
index 83c644a..f9878e4 100644
--- a/yaksh/models.py
+++ b/yaksh/models.py
@@ -11,6 +11,7 @@ from collections import Counter, defaultdict
from django.db import models
from django.contrib.auth.models import User, Group, Permission
+from django.core.exceptions import ValidationError
from django.contrib.contenttypes.models import ContentType
from taggit.managers import TaggableManager
from django.utils import timezone
@@ -233,6 +234,18 @@ def render_template(template_path, data=None):
return render
+def validate_image(image):
+ file_size = image.file.size
+ limit_mb = 30
+ if file_size > limit_mb * 1024 * 1024:
+ raise ValidationError("Max size of file is {0} MB".format(limit_mb))
+
+
+def get_image_dir(instance, filename):
+ return os.sep.join((
+ 'thread_%s' % (instance), filename
+ ))
+
###############################################################################
class CourseManager(models.Manager):
@@ -2634,16 +2647,21 @@ class TestCaseOrder(models.Model):
order = models.TextField()
##############################################################################
-class Thread(models.Model):
+class ForumBase(models.Model):
uid = models.UUIDField(unique=True, default=uuid.uuid4, editable=False)
creator = models.ForeignKey(User, on_delete=models.CASCADE)
- title = models.CharField(max_length=200)
description = models.TextField()
- course = models.ForeignKey(Course,
- on_delete=models.CASCADE, related_name='thread')
created_at = models.DateTimeField(auto_now_add=True)
modified_at = models.DateTimeField(auto_now=True)
- # image = models.ImageField(upload_to='images/%y/%m/%d', blank=True)
+ image = models.ImageField(upload_to=get_image_dir, blank=True,
+ null=True, validators=[validate_image])
+ active = models.BooleanField(default=True)
+
+
+class Thread(ForumBase):
+ title = models.CharField(max_length=200)
+ course = models.ForeignKey(Course,
+ on_delete=models.CASCADE, related_name='thread')
def __str__(self):
return self.title
@@ -2654,20 +2672,12 @@ class Thread(models.Model):
def get_comments_count(self):
return self.comment.count()
-##############################################################################
-class Comment(models.Model):
- uid = models.UUIDField(unique=True, default=uuid.uuid4, editable=False)
- user = models.ForeignKey(User, on_delete=models.CASCADE)
- thread = models.ForeignKey(Thread,
+
+class Comment(ForumBase):
+ thread_field = models.ForeignKey(Thread,
on_delete=models.CASCADE,
related_name='comment')
- body = models.TextField()
- created_at = models.DateTimeField(auto_now_add=True)
- modified_at = models.DateTimeField(auto_now=True)
- active = models.BooleanField(default=True) #make it false if improper comment
- # image = models.ImageField(upload_to='images/%y/%m/%d', blank=True)
-
def __str__(self):
- return 'Comment by {0}: \n {1}'.format(self.user.username,
- self.thread.title)
+ return 'Comment by {0}: {1}'.format(self.creator.username,
+ self.thread_field.title)