summaryrefslogtreecommitdiff
path: root/pgweb/sponsors/models.py
blob: d11334856e8df22fa5f6163dec65bb97deedbf2a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
from django.db import models

from pgweb.core.models import Country


class SponsorType(models.Model):
    typename = models.CharField(max_length=32, null=False, blank=False)
    description = models.TextField(null=False, blank=False)
    sortkey = models.IntegerField(null=False, default=10)
    # sortkey==0 --> do not show in list

    purge_urls = ('/about/servers/', '/about/contributing/', )

    def __str__(self):
        return self.typename

    class Meta:
        ordering = ('sortkey', )


class Sponsor(models.Model):
    sponsortype = models.ForeignKey(SponsorType, null=False, on_delete=models.CASCADE)
    name = models.CharField(max_length=128, null=False, blank=False)
    url = models.URLField(null=False, blank=False)
    logoname = models.CharField(max_length=64, null=False, blank=False)
    country = models.ForeignKey(Country, null=False, on_delete=models.CASCADE)

    purge_urls = ('/about/servers/', '/about/contributing/', )

    def __str__(self):
        return self.name

    class Meta:
        ordering = ('name', )


class Server(models.Model):
    name = models.CharField(max_length=32, null=False, blank=False)
    sponsors = models.ManyToManyField(Sponsor)
    dedicated = models.BooleanField(null=False, default=True)
    performance = models.CharField(max_length=128, null=False, blank=False)
    os = models.CharField(max_length=32, null=False, blank=False)
    location = models.CharField(max_length=128, null=False, blank=False)
    usage = models.TextField(null=False, blank=False)

    purge_urls = ('/about/servers/', )

    def __str__(self):
        return self.name

    class Meta:
        ordering = ('name', )