summaryrefslogtreecommitdiff
path: root/news/models.py
diff options
context:
space:
mode:
Diffstat (limited to 'news/models.py')
-rw-r--r--news/models.py39
1 files changed, 33 insertions, 6 deletions
diff --git a/news/models.py b/news/models.py
index 6c8a7039..a66da8d4 100644
--- a/news/models.py
+++ b/news/models.py
@@ -1,19 +1,29 @@
from django.db import models
from django.contrib.auth.models import User
+from django.contrib.sites.models import Site
+from django.utils.safestring import mark_safe
+from django.utils.timezone import now
+
+from main.utils import parse_markdown
+
class News(models.Model):
- id = models.AutoField(primary_key=True)
slug = models.SlugField(max_length=255, unique=True)
- author = models.ForeignKey(User, related_name='news_author')
- postdate = models.DateTimeField("post date", auto_now_add=True, db_index=True)
- last_modified = models.DateTimeField(editable=False,
- auto_now=True, db_index=True)
+ author = models.ForeignKey(User, related_name='news_author',
+ on_delete=models.PROTECT)
+ postdate = models.DateTimeField("post date", db_index=True)
+ last_modified = models.DateTimeField(editable=False, db_index=True)
title = models.CharField(max_length=255)
+ guid = models.CharField(max_length=255, editable=False)
content = models.TextField()
+ safe_mode = models.BooleanField(default=True)
def get_absolute_url(self):
return '/news/%s/' % self.slug
+ def html(self):
+ return mark_safe(parse_markdown(self.content, not self.safe_mode))
+
def __unicode__(self):
return self.title
@@ -21,6 +31,23 @@ class News(models.Model):
db_table = 'news'
verbose_name_plural = 'news'
get_latest_by = 'postdate'
- ordering = ['-postdate']
+ ordering = ('-postdate',)
+
+
+def set_news_fields(sender, **kwargs):
+ news = kwargs['instance']
+ current_time = now()
+ news.last_modified = current_time
+ if not news.postdate:
+ news.postdate = current_time
+ # http://diveintomark.org/archives/2004/05/28/howto-atom-id
+ news.guid = 'tag:%s,%s:%s' % (Site.objects.get_current(),
+ current_time.strftime('%Y-%m-%d'), news.get_absolute_url())
+
+
+from django.db.models.signals import pre_save
+
+pre_save.connect(set_news_fields, sender=News,
+ dispatch_uid="news.models")
# vim: set ts=4 sw=4 et: