annotate weblinks/models.py @ 1206:02181fa5ac9d modernize tip

Update to Django 1.9.
author Brian Neal <bgneal@gmail.com>
date Wed, 22 Jan 2025 17:58:16 -0600
parents eeaf387803c6
children
rev   line source
bgneal@193 1 """
gremmie@1 2 This module contains the models for the weblinks application.
bgneal@193 3 """
bgneal@204 4 import datetime
bgneal@204 5
bgneal@1035 6 from django.contrib.auth.models import User
bgneal@1035 7 from django.core.urlresolvers import reverse
gremmie@1 8 from django.db import models
gremmie@1 9
gremmie@1 10
gremmie@1 11 class Category(models.Model):
bgneal@193 12 """Links belong to categories"""
bgneal@193 13 title = models.CharField(max_length=64)
bgneal@242 14 slug = models.SlugField(max_length=64)
bgneal@193 15 description = models.TextField(blank=True)
bgneal@193 16 count = models.IntegerField(default=0)
gremmie@1 17
gremmie@1 18 def __unicode__(self):
gremmie@1 19 return self.title
gremmie@1 20
gremmie@1 21 class Meta:
gremmie@1 22 verbose_name_plural = 'Categories'
gremmie@1 23 ordering = ('title', )
gremmie@1 24
gremmie@1 25
gremmie@1 26 class PublicLinkManager(models.Manager):
gremmie@1 27 """The manager for all public links."""
bgneal@740 28 def get_queryset(self):
bgneal@740 29 return super(PublicLinkManager, self).get_queryset().filter(
bgneal@191 30 is_public=True).select_related()
gremmie@1 31
gremmie@1 32
bgneal@204 33 class LinkBase(models.Model):
bgneal@204 34 """Abstract model to aggregate common fields of a web link."""
bgneal@1206 35 category = models.ForeignKey(Category, on_delete=models.CASCADE)
gremmie@1 36 title = models.CharField(max_length=128)
bgneal@572 37 url = models.URLField(db_index=True)
gremmie@1 38 description = models.TextField(blank=True)
bgneal@1206 39 user = models.ForeignKey(User, on_delete=models.CASCADE)
bgneal@277 40 date_added = models.DateTimeField(db_index=True)
bgneal@277 41 update_date = models.DateTimeField(db_index=True, blank=True)
bgneal@204 42
bgneal@204 43 class Meta:
bgneal@204 44 abstract = True
bgneal@204 45
bgneal@204 46
bgneal@204 47 class Link(LinkBase):
bgneal@204 48 """Model to represent a web link"""
gremmie@1 49 hits = models.IntegerField(default=0)
gremmie@1 50 is_public = models.BooleanField(default=False, db_index=True)
gremmie@1 51
gremmie@1 52 # Managers:
gremmie@1 53 objects = models.Manager()
gremmie@1 54 public_objects = PublicLinkManager()
gremmie@1 55
bgneal@20 56 class Meta:
bgneal@20 57 ordering = ('title', )
bgneal@20 58
gremmie@1 59 def __unicode__(self):
gremmie@1 60 return self.title
gremmie@1 61
bgneal@277 62 def save(self, *args, **kwargs):
bgneal@277 63 if not self.pk:
bgneal@277 64 if not self.date_added:
bgneal@277 65 self.date_added = datetime.datetime.now()
bgneal@277 66 self.update_date = self.date_added
bgneal@277 67 else:
bgneal@277 68 self.update_date = datetime.datetime.now()
bgneal@277 69
bgneal@277 70 super(Link, self).save(*args, **kwargs)
bgneal@277 71
bgneal@20 72 def get_absolute_url(self):
bgneal@1035 73 return reverse('weblinks-link_detail', args=[str(self.pk)])
gremmie@1 74
bgneal@220 75 def search_title(self):
bgneal@220 76 return self.title
bgneal@220 77
bgneal@220 78 def search_summary(self):
bgneal@220 79 return self.description
bgneal@220 80
gremmie@1 81
bgneal@204 82 class PendingLink(LinkBase):
bgneal@204 83 """This model represents links that users submit. They must be approved by
bgneal@204 84 an admin before they become visible on the site.
bgneal@204 85 """
bgneal@204 86 class Meta:
bgneal@204 87 ordering = ('date_added', )
bgneal@204 88
bgneal@204 89 def __unicode__(self):
bgneal@204 90 return self.title
bgneal@204 91
bgneal@204 92 def save(self, *args, **kwargs):
bgneal@204 93 if not self.pk:
bgneal@204 94 self.date_added = datetime.datetime.now()
bgneal@277 95 self.update_date = self.date_added
bgneal@277 96 else:
bgneal@277 97 self.update_date = datetime.datetime.now()
bgneal@277 98
bgneal@204 99 super(PendingLink, self).save(*args, **kwargs)
bgneal@204 100
bgneal@204 101
gremmie@1 102 class FlaggedLinkManager(models.Manager):
gremmie@1 103
gremmie@1 104 def create(self, link, user):
gremmie@1 105 flagged_link = FlaggedLink(link = link, user = user, approved = False)
gremmie@1 106 flagged_link.save()
gremmie@1 107
gremmie@1 108
gremmie@1 109 class FlaggedLink(models.Model):
bgneal@193 110 """Model to represent links that have been flagged as broken by users"""
bgneal@1206 111 link = models.ForeignKey(Link, on_delete=models.CASCADE)
bgneal@1206 112 user = models.ForeignKey(User, on_delete=models.CASCADE)
gremmie@1 113 date_flagged = models.DateField(auto_now_add = True)
bgneal@675 114 approved = models.BooleanField(default = False,
gremmie@1 115 help_text = 'Check this and save to remove the referenced link from the database')
gremmie@1 116
gremmie@1 117 objects = FlaggedLinkManager()
gremmie@1 118
bgneal@182 119 def save(self, *args, **kwargs):
gremmie@1 120 if self.approved:
gremmie@1 121 self.link.delete()
gremmie@1 122 self.delete()
gremmie@1 123 else:
bgneal@182 124 super(FlaggedLink, self).save(*args, **kwargs)
gremmie@1 125
gremmie@1 126 def url(self):
gremmie@1 127 return self.link.url
gremmie@1 128
bgneal@165 129 def get_link_url(self):
bgneal@165 130 return '<a href="%s">Link #%d</a>' % (self.link.get_absolute_url(),
bgneal@165 131 self.link.id)
bgneal@165 132 get_link_url.allow_tags = True
bgneal@165 133 get_link_url.short_description = "View Link on Site"
bgneal@165 134
gremmie@1 135 def __unicode__(self):
gremmie@1 136 return self.link.title
gremmie@1 137
gremmie@1 138 class Meta:
gremmie@1 139 ordering = ('-date_flagged', )