mirror of
https://github.com/postgres/pgweb.git
synced 2025-07-25 16:02:27 +00:00

This makes it possible to figure out when the docs were actually loaded, since developer docs don't carry a version number. This is actually going to be the docs *load* timestamp, and not build timestamp, but they should be close enough together that it shouldn't matter. Fixes #108
119 lines
4.2 KiB
Python
119 lines
4.2 KiB
Python
from django.db import models
|
|
from django.contrib.auth.models import User
|
|
from pgweb.util.bases import PgModel
|
|
from pgweb.util.misc import varnish_purge
|
|
|
|
from datetime import datetime
|
|
|
|
class Version(PgModel, models.Model):
|
|
tree = models.DecimalField(max_digits=3, decimal_places=1, null=False, blank=False)
|
|
latestminor = models.IntegerField(null=False, blank=False, default=0)
|
|
reldate = models.DateField(null=False, blank=False)
|
|
relnotes = models.CharField(max_length=32, null=False, blank=False)
|
|
current = models.BooleanField(null=False, blank=False, default=False)
|
|
supported = models.BooleanField(null=False, blank=False, default=True)
|
|
docsloaded = models.DateTimeField(null=True, blank=True, help_text="The timestamp of the latest docs load. Really only used for developer docs for now, but set for all of them.")
|
|
|
|
def __unicode__(self):
|
|
return self.versionstring
|
|
|
|
@property
|
|
def versionstring(self):
|
|
return "%s.%s" % (self.tree, self.latestminor)
|
|
|
|
def save(self):
|
|
# Make sure only one version at a time can be the current one.
|
|
# (there may be some small race conditions here, but the likelyhood
|
|
# that two admins are editing the version list at the same time...)
|
|
if self.current:
|
|
previous = Version.objects.filter(current=True)
|
|
for p in previous:
|
|
if not p == self:
|
|
p.current = False
|
|
p.save() # primary key check avoids recursion
|
|
|
|
# Now that we've made any previously current ones non-current, we are
|
|
# free to save this one.
|
|
super(Version, self).save()
|
|
|
|
class Meta:
|
|
ordering = ('-tree', )
|
|
|
|
def purge_urls(self):
|
|
yield '/$'
|
|
yield '/support/submitbug'
|
|
yield '/versions.rss'
|
|
|
|
|
|
class Country(models.Model):
|
|
name = models.CharField(max_length=100, null=False, blank=False)
|
|
tld = models.CharField(max_length=3, null=False, blank=False)
|
|
|
|
class Meta:
|
|
db_table = 'countries'
|
|
ordering = ('name',)
|
|
verbose_name = 'Country'
|
|
verbose_name_plural = 'Countries'
|
|
|
|
def __unicode__(self):
|
|
return self.name
|
|
|
|
class OrganisationType(models.Model):
|
|
typename = models.CharField(max_length=32, null=False, blank=False)
|
|
|
|
def __unicode__(self):
|
|
return self.typename
|
|
|
|
class Organisation(PgModel, models.Model):
|
|
name = models.CharField(max_length=100, null=False, blank=False, unique=True)
|
|
approved = models.BooleanField(null=False, default=False)
|
|
address = models.TextField(null=False, blank=True)
|
|
url = models.URLField(null=False, blank=False)
|
|
email = models.EmailField(null=False, blank=True)
|
|
phone = models.CharField(max_length=100, null=False, blank=True)
|
|
orgtype = models.ForeignKey(OrganisationType, null=False, blank=False, verbose_name="Organisation type")
|
|
managers = models.ManyToManyField(User, null=False, blank=False)
|
|
lastconfirmed = models.DateTimeField(null=False, blank=False, default=datetime.now())
|
|
|
|
send_notification = True
|
|
|
|
def __unicode__(self):
|
|
return self.name
|
|
|
|
class Meta:
|
|
ordering = ('name',)
|
|
|
|
|
|
# Basic classes for importing external RSS feeds, such as planet
|
|
class ImportedRSSFeed(models.Model):
|
|
internalname = models.CharField(max_length=32, null=False, blank=False, unique=True)
|
|
url = models.URLField(null=False, blank=False)
|
|
purgepattern = models.CharField(max_length=512, null=False, blank=True, help_text="NOTE! Pattern will be automatically anchored with ^ at the beginning, but you must lead with a slash in most cases - and don't forget to include the trailing $ in most cases")
|
|
|
|
def purge_related(self):
|
|
if self.purgepattern:
|
|
varnish_purge(self.purgepattern)
|
|
|
|
def __unicode__(self):
|
|
return self.internalname
|
|
|
|
class ImportedRSSItem(models.Model):
|
|
feed = models.ForeignKey(ImportedRSSFeed)
|
|
title = models.CharField(max_length=100, null=False, blank=False)
|
|
url = models.URLField(null=False, blank=False)
|
|
posttime = models.DateTimeField(null=False, blank=False)
|
|
|
|
def __unicode__(self):
|
|
return self.title
|
|
|
|
@property
|
|
def date(self):
|
|
return self.posttime.strftime("%Y-%m-%d")
|
|
|
|
|
|
# Extra attributes for users (if they have them)
|
|
class UserProfile(models.Model):
|
|
user = models.ForeignKey(User, null=False, blank=False, unique=True, primary_key=True)
|
|
sshkey = models.TextField(null=False, blank=True, verbose_name="SSH key", help_text= "Paste one or more public keys in OpenSSH format, one per line.")
|
|
lastmodified = models.DateTimeField(null=False, blank=False, auto_now=True)
|