2009-12-22 18:29:00 +00:00
|
|
|
import datetime
|
2015-01-28 07:35:27 -05:00
|
|
|
import tempfile
|
2016-01-07 11:07:15 +02:00
|
|
|
import uuid
|
2009-12-22 18:29:00 +00:00
|
|
|
|
2021-01-13 16:19:22 +00:00
|
|
|
from django.contrib import admin
|
2010-08-06 14:58:05 +00:00
|
|
|
from django.contrib.auth.models import User
|
2022-02-03 20:24:19 +01:00
|
|
|
from django.contrib.contenttypes.fields import GenericForeignKey, GenericRelation
|
2010-02-26 13:17:43 +00:00
|
|
|
from django.contrib.contenttypes.models import ContentType
|
2015-04-24 20:31:26 -05:00
|
|
|
from django.core.exceptions import ValidationError
|
2011-10-13 18:51:33 +00:00
|
|
|
from django.core.files.storage import FileSystemStorage
|
|
|
|
from django.db import models
|
2023-09-14 17:40:20 +05:30
|
|
|
from django.utils import timezone
|
2008-07-18 23:54:34 +00:00
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2008-07-18 23:54:34 +00:00
|
|
|
class Section(models.Model):
|
|
|
|
"""
|
2008-08-08 18:07:33 +00:00
|
|
|
A simple section that links to articles, to test linking to related items
|
2008-07-18 23:54:34 +00:00
|
|
|
in admin views.
|
|
|
|
"""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
2008-07-18 23:54:34 +00:00
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
|
2016-01-08 10:21:27 -05:00
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
|
|
|
|
2015-03-08 11:50:32 +01:00
|
|
|
@property
|
|
|
|
def name_property(self):
|
|
|
|
"""
|
|
|
|
A property that simply returns the name. Used to test #24461
|
|
|
|
"""
|
|
|
|
return self.name
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2008-07-18 23:54:34 +00:00
|
|
|
class Article(models.Model):
|
|
|
|
"""
|
|
|
|
A simple article to test admin views. Test backwards compatibility.
|
|
|
|
"""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
2008-08-08 18:07:33 +00:00
|
|
|
title = models.CharField(max_length=100)
|
2008-07-18 23:54:34 +00:00
|
|
|
content = models.TextField()
|
|
|
|
date = models.DateTimeField()
|
2015-07-22 09:43:21 -05:00
|
|
|
section = models.ForeignKey(Section, models.CASCADE, null=True, blank=True)
|
2022-02-03 20:24:19 +01:00
|
|
|
another_section = models.ForeignKey(
|
|
|
|
Section, models.CASCADE, null=True, blank=True, related_name="+"
|
|
|
|
)
|
|
|
|
sub_section = models.ForeignKey(
|
|
|
|
Section, models.SET_NULL, null=True, blank=True, related_name="+"
|
|
|
|
)
|
2008-07-18 23:54:34 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2008-08-08 18:07:33 +00:00
|
|
|
return self.title
|
2009-03-10 11:19:26 +00:00
|
|
|
|
2022-02-03 20:24:19 +01:00
|
|
|
@admin.display(ordering="date", description="")
|
2008-10-08 14:47:01 +00:00
|
|
|
def model_year(self):
|
|
|
|
return self.date.year
|
|
|
|
|
2022-02-03 20:24:19 +01:00
|
|
|
@admin.display(ordering="-date", description="")
|
2014-01-23 03:13:59 +01:00
|
|
|
def model_year_reversed(self):
|
|
|
|
return self.date.year
|
|
|
|
|
2021-01-13 16:19:22 +00:00
|
|
|
@property
|
2022-02-03 20:24:19 +01:00
|
|
|
@admin.display(ordering="date")
|
2021-01-13 16:19:22 +00:00
|
|
|
def model_property_year(self):
|
2019-03-19 17:51:35 +02:00
|
|
|
return self.date.year
|
|
|
|
|
2019-04-01 15:11:54 +02:00
|
|
|
@property
|
|
|
|
def model_month(self):
|
|
|
|
return self.date.month
|
|
|
|
|
2023-09-14 17:40:20 +05:30
|
|
|
@property
|
|
|
|
@admin.display(description="Is from past?", boolean=True)
|
|
|
|
def model_property_is_from_past(self):
|
|
|
|
return self.date < timezone.now()
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2008-12-16 15:04:47 +00:00
|
|
|
class Book(models.Model):
|
|
|
|
"""
|
|
|
|
A simple book that has chapters.
|
|
|
|
"""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
|
|
|
name = models.CharField(max_length=100, verbose_name="¿Name?")
|
2008-12-16 17:42:18 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2008-12-16 17:42:18 +00:00
|
|
|
return self.name
|
|
|
|
|
2023-11-15 14:32:03 -05:00
|
|
|
def get_absolute_url(self):
|
|
|
|
return f"/books/{self.id}/"
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2008-12-16 17:42:18 +00:00
|
|
|
class Promo(models.Model):
|
2022-02-03 20:24:19 +01:00
|
|
|
name = models.CharField(max_length=100, verbose_name="¿Name?")
|
2015-07-22 09:43:21 -05:00
|
|
|
book = models.ForeignKey(Book, models.CASCADE)
|
2017-06-04 14:10:48 -04:00
|
|
|
author = models.ForeignKey(User, models.SET_NULL, blank=True, null=True)
|
2008-12-16 17:42:18 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2008-12-16 17:42:18 +00:00
|
|
|
return self.name
|
2008-12-16 15:04:47 +00:00
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2008-12-16 15:04:47 +00:00
|
|
|
class Chapter(models.Model):
|
2022-02-03 20:24:19 +01:00
|
|
|
title = models.CharField(max_length=100, verbose_name="¿Title?")
|
2008-12-16 15:04:47 +00:00
|
|
|
content = models.TextField()
|
2015-07-22 09:43:21 -05:00
|
|
|
book = models.ForeignKey(Book, models.CASCADE)
|
2008-12-16 15:04:47 +00:00
|
|
|
|
2008-12-16 17:42:18 +00:00
|
|
|
class Meta:
|
2010-03-02 03:28:48 +00:00
|
|
|
# Use a utf-8 bytestring to ensure it works (see #11710)
|
2022-02-03 20:24:19 +01:00
|
|
|
verbose_name = "¿Chapter?"
|
2008-12-16 17:42:18 +00:00
|
|
|
|
2018-12-27 16:34:14 -08:00
|
|
|
def __str__(self):
|
|
|
|
return self.title
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2008-12-16 17:42:18 +00:00
|
|
|
class ChapterXtra1(models.Model):
|
2022-02-03 20:24:19 +01:00
|
|
|
chap = models.OneToOneField(Chapter, models.CASCADE, verbose_name="¿Chap?")
|
|
|
|
xtra = models.CharField(max_length=100, verbose_name="¿Xtra?")
|
2017-06-04 14:10:48 -04:00
|
|
|
guest_author = models.ForeignKey(User, models.SET_NULL, blank=True, null=True)
|
2008-12-16 17:42:18 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2022-02-03 20:24:19 +01:00
|
|
|
return "¿Xtra1: %s" % self.xtra
|
2008-12-16 17:42:18 +00:00
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2008-12-16 17:42:18 +00:00
|
|
|
class ChapterXtra2(models.Model):
|
2022-02-03 20:24:19 +01:00
|
|
|
chap = models.OneToOneField(Chapter, models.CASCADE, verbose_name="¿Chap?")
|
|
|
|
xtra = models.CharField(max_length=100, verbose_name="¿Xtra?")
|
2008-12-16 17:42:18 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2022-02-03 20:24:19 +01:00
|
|
|
return "¿Xtra2: %s" % self.xtra
|
2008-12-16 17:42:18 +00:00
|
|
|
|
2010-11-21 19:00:40 +00:00
|
|
|
|
2011-02-19 14:05:07 +00:00
|
|
|
class RowLevelChangePermissionModel(models.Model):
|
|
|
|
name = models.CharField(max_length=100, blank=True)
|
|
|
|
|
2010-11-21 19:00:40 +00:00
|
|
|
|
2008-07-18 23:54:34 +00:00
|
|
|
class CustomArticle(models.Model):
|
|
|
|
content = models.TextField()
|
|
|
|
date = models.DateTimeField()
|
|
|
|
|
|
|
|
|
|
|
|
class ModelWithStringPrimaryKey(models.Model):
|
2012-06-07 17:34:25 +02:00
|
|
|
string_pk = models.CharField(max_length=255, primary_key=True)
|
2008-08-08 18:07:33 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2012-06-07 17:34:25 +02:00
|
|
|
return self.string_pk
|
|
|
|
|
|
|
|
def get_absolute_url(self):
|
2022-02-03 20:24:19 +01:00
|
|
|
return "/dummy/%s/" % self.string_pk
|
2008-08-08 18:07:33 +00:00
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2008-10-21 19:03:21 +00:00
|
|
|
class Color(models.Model):
|
|
|
|
value = models.CharField(max_length=10)
|
2013-08-11 21:19:09 +01:00
|
|
|
warm = models.BooleanField(default=False)
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2008-10-21 19:03:21 +00:00
|
|
|
return self.value
|
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2012-02-09 18:59:05 +00:00
|
|
|
# we replicate Color to register with another ModelAdmin
|
|
|
|
class Color2(Color):
|
|
|
|
class Meta:
|
|
|
|
proxy = True
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2008-10-21 19:03:21 +00:00
|
|
|
class Thing(models.Model):
|
|
|
|
title = models.CharField(max_length=20)
|
2022-02-03 20:24:19 +01:00
|
|
|
color = models.ForeignKey(Color, models.CASCADE, limit_choices_to={"warm": True})
|
2012-09-15 16:20:56 -07:00
|
|
|
pub_date = models.DateField(blank=True, null=True)
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2008-10-21 19:03:21 +00:00
|
|
|
return self.title
|
|
|
|
|
|
|
|
|
2011-01-28 14:08:25 +00:00
|
|
|
class Actor(models.Model):
|
|
|
|
name = models.CharField(max_length=50)
|
|
|
|
age = models.IntegerField()
|
2013-02-26 00:27:52 -03:00
|
|
|
title = models.CharField(max_length=50, null=True, blank=True)
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2011-01-28 14:08:25 +00:00
|
|
|
return self.name
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2011-01-28 14:08:25 +00:00
|
|
|
class Inquisition(models.Model):
|
2013-08-11 21:19:09 +01:00
|
|
|
expected = models.BooleanField(default=False)
|
2015-07-22 09:43:21 -05:00
|
|
|
leader = models.ForeignKey(Actor, models.CASCADE)
|
2011-01-28 14:08:42 +00:00
|
|
|
country = models.CharField(max_length=20)
|
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2012-06-07 18:08:47 +02:00
|
|
|
return "by %s from %s" % (self.leader, self.country)
|
2011-01-28 14:08:42 +00:00
|
|
|
|
2011-01-28 14:08:25 +00:00
|
|
|
|
|
|
|
class Sketch(models.Model):
|
|
|
|
title = models.CharField(max_length=100)
|
2015-07-22 09:43:21 -05:00
|
|
|
inquisition = models.ForeignKey(
|
|
|
|
Inquisition,
|
|
|
|
models.CASCADE,
|
|
|
|
limit_choices_to={
|
2022-02-03 20:24:19 +01:00
|
|
|
"leader__name": "Palin",
|
|
|
|
"leader__age": 27,
|
|
|
|
"expected": False,
|
2015-07-22 09:43:21 -05:00
|
|
|
},
|
|
|
|
)
|
|
|
|
defendant0 = models.ForeignKey(
|
|
|
|
Actor,
|
|
|
|
models.CASCADE,
|
2022-02-03 20:24:19 +01:00
|
|
|
limit_choices_to={"title__isnull": False},
|
|
|
|
related_name="as_defendant0",
|
2015-07-22 09:43:21 -05:00
|
|
|
)
|
|
|
|
defendant1 = models.ForeignKey(
|
|
|
|
Actor,
|
|
|
|
models.CASCADE,
|
2022-02-03 20:24:19 +01:00
|
|
|
limit_choices_to={"title__isnull": True},
|
|
|
|
related_name="as_defendant1",
|
2015-07-22 09:43:21 -05:00
|
|
|
)
|
2011-01-28 14:08:42 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2011-01-28 14:08:25 +00:00
|
|
|
return self.title
|
|
|
|
|
2011-01-28 14:08:42 +00:00
|
|
|
|
2014-02-01 14:23:31 -05:00
|
|
|
def today_callable_dict():
|
|
|
|
return {"last_action__gte": datetime.datetime.today()}
|
|
|
|
|
|
|
|
|
|
|
|
def today_callable_q():
|
|
|
|
return models.Q(last_action__gte=datetime.datetime.today())
|
|
|
|
|
|
|
|
|
|
|
|
class Character(models.Model):
|
|
|
|
username = models.CharField(max_length=100)
|
|
|
|
last_action = models.DateTimeField()
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.username
|
|
|
|
|
|
|
|
|
|
|
|
class StumpJoke(models.Model):
|
|
|
|
variation = models.CharField(max_length=100)
|
2015-07-22 09:43:21 -05:00
|
|
|
most_recently_fooled = models.ForeignKey(
|
|
|
|
Character,
|
|
|
|
models.CASCADE,
|
|
|
|
limit_choices_to=today_callable_dict,
|
|
|
|
related_name="+",
|
|
|
|
)
|
2022-02-03 20:24:19 +01:00
|
|
|
has_fooled_today = models.ManyToManyField(
|
|
|
|
Character, limit_choices_to=today_callable_q, related_name="+"
|
|
|
|
)
|
2014-02-01 14:23:31 -05:00
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.variation
|
|
|
|
|
|
|
|
|
2009-04-01 14:14:20 +00:00
|
|
|
class Fabric(models.Model):
|
|
|
|
NG_CHOICES = (
|
2022-02-03 20:24:19 +01:00
|
|
|
(
|
|
|
|
"Textured",
|
|
|
|
(
|
|
|
|
("x", "Horizontal"),
|
|
|
|
("y", "Vertical"),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
("plain", "Smooth"),
|
2009-04-01 14:14:20 +00:00
|
|
|
)
|
|
|
|
surface = models.CharField(max_length=20, choices=NG_CHOICES)
|
|
|
|
|
|
|
|
|
2009-03-17 20:51:47 +00:00
|
|
|
class Person(models.Model):
|
|
|
|
GENDER_CHOICES = (
|
|
|
|
(1, "Male"),
|
|
|
|
(2, "Female"),
|
|
|
|
)
|
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
gender = models.IntegerField(choices=GENDER_CHOICES)
|
2011-01-03 13:56:31 +00:00
|
|
|
age = models.IntegerField(default=21)
|
2013-03-24 15:27:27 +01:00
|
|
|
alive = models.BooleanField(default=True)
|
2009-03-29 18:52:38 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2009-03-17 20:51:47 +00:00
|
|
|
return self.name
|
2009-03-29 18:52:38 +00:00
|
|
|
|
2010-02-16 12:17:37 +00:00
|
|
|
|
2009-03-10 11:19:26 +00:00
|
|
|
class Persona(models.Model):
|
|
|
|
"""
|
|
|
|
A simple persona associated with accounts, to test inlining of related
|
|
|
|
accounts which inherit from a common accounts class.
|
|
|
|
"""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
2013-03-24 15:27:27 +01:00
|
|
|
name = models.CharField(blank=False, max_length=80)
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2009-03-10 11:19:26 +00:00
|
|
|
return self.name
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2009-03-10 11:19:26 +00:00
|
|
|
class Account(models.Model):
|
|
|
|
"""
|
|
|
|
A simple, generic account encapsulating the information shared by all
|
|
|
|
types of accounts.
|
|
|
|
"""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
2013-03-24 15:27:27 +01:00
|
|
|
username = models.CharField(blank=False, max_length=80)
|
2015-07-22 09:43:21 -05:00
|
|
|
persona = models.ForeignKey(Persona, models.CASCADE, related_name="accounts")
|
2022-02-03 20:24:19 +01:00
|
|
|
servicename = "generic service"
|
2009-03-10 11:19:26 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2009-03-10 11:19:26 +00:00
|
|
|
return "%s: %s" % (self.servicename, self.username)
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2009-03-10 11:19:26 +00:00
|
|
|
class FooAccount(Account):
|
|
|
|
"""A service-specific account of type Foo."""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
|
|
|
servicename = "foo"
|
2009-03-10 11:19:26 +00:00
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2009-03-10 11:19:26 +00:00
|
|
|
class BarAccount(Account):
|
|
|
|
"""A service-specific account of type Bar."""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
|
|
|
servicename = "bar"
|
2009-03-10 11:19:26 +00:00
|
|
|
|
|
|
|
|
2009-03-23 20:22:56 +00:00
|
|
|
class Subscriber(models.Model):
|
|
|
|
name = models.CharField(blank=False, max_length=80)
|
|
|
|
email = models.EmailField(blank=False, max_length=175)
|
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2009-03-23 20:22:56 +00:00
|
|
|
return "%s (%s)" % (self.name, self.email)
|
|
|
|
|
|
|
|
|
|
|
|
class ExternalSubscriber(Subscriber):
|
|
|
|
pass
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2009-04-06 20:23:33 +00:00
|
|
|
class OldSubscriber(Subscriber):
|
|
|
|
pass
|
|
|
|
|
2009-03-17 20:51:47 +00:00
|
|
|
|
2009-03-29 18:52:38 +00:00
|
|
|
class Media(models.Model):
|
|
|
|
name = models.CharField(max_length=60)
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2009-03-29 18:52:38 +00:00
|
|
|
class Podcast(Media):
|
|
|
|
release_date = models.DateField()
|
|
|
|
|
2011-06-02 16:18:47 +00:00
|
|
|
class Meta:
|
2022-02-03 20:24:19 +01:00
|
|
|
ordering = ("release_date",) # overridden in PodcastAdmin
|
2011-06-02 16:18:47 +00:00
|
|
|
|
2009-03-29 18:52:38 +00:00
|
|
|
|
2009-04-18 21:03:29 +00:00
|
|
|
class Vodcast(Media):
|
2022-02-03 20:24:19 +01:00
|
|
|
media = models.OneToOneField(
|
|
|
|
Media, models.CASCADE, primary_key=True, parent_link=True
|
|
|
|
)
|
2009-04-18 21:03:29 +00:00
|
|
|
released = models.BooleanField(default=False)
|
|
|
|
|
|
|
|
|
2009-03-31 00:03:34 +00:00
|
|
|
class Parent(models.Model):
|
|
|
|
name = models.CharField(max_length=128)
|
|
|
|
|
2015-04-24 20:31:26 -05:00
|
|
|
def clean(self):
|
2022-02-03 20:24:19 +01:00
|
|
|
if self.name == "_invalid":
|
|
|
|
raise ValidationError("invalid")
|
2015-04-24 20:31:26 -05:00
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2009-03-31 00:03:34 +00:00
|
|
|
class Child(models.Model):
|
2015-07-22 09:43:21 -05:00
|
|
|
parent = models.ForeignKey(Parent, models.CASCADE, editable=False)
|
2009-03-31 00:03:34 +00:00
|
|
|
name = models.CharField(max_length=30, blank=True)
|
|
|
|
|
2015-04-24 20:31:26 -05:00
|
|
|
def clean(self):
|
2022-02-03 20:24:19 +01:00
|
|
|
if self.name == "_invalid":
|
|
|
|
raise ValidationError("invalid")
|
2015-04-24 20:31:26 -05:00
|
|
|
|
2009-03-31 00:03:34 +00:00
|
|
|
|
2021-03-18 11:21:23 +01:00
|
|
|
class PKChild(models.Model):
|
|
|
|
"""
|
|
|
|
Used to check autocomplete to_field resolution when ForeignKey is PK.
|
|
|
|
"""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
2021-03-18 11:21:23 +01:00
|
|
|
parent = models.ForeignKey(Parent, models.CASCADE, primary_key=True)
|
|
|
|
name = models.CharField(max_length=128)
|
|
|
|
|
|
|
|
class Meta:
|
2022-02-03 20:24:19 +01:00
|
|
|
ordering = ["parent"]
|
2021-03-18 11:21:23 +01:00
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
|
|
|
|
|
|
|
|
|
|
|
class Toy(models.Model):
|
|
|
|
child = models.ForeignKey(PKChild, models.CASCADE)
|
|
|
|
|
|
|
|
|
2009-04-01 03:11:58 +00:00
|
|
|
class EmptyModel(models.Model):
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2009-04-01 03:11:58 +00:00
|
|
|
return "Primary key = %s" % self.id
|
|
|
|
|
2009-04-06 20:23:33 +00:00
|
|
|
|
2015-02-21 18:56:36 +01:00
|
|
|
temp_storage = FileSystemStorage(tempfile.mkdtemp())
|
2009-04-18 20:29:55 +00:00
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2009-04-18 20:29:55 +00:00
|
|
|
class Gallery(models.Model):
|
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2009-04-18 20:29:55 +00:00
|
|
|
class Picture(models.Model):
|
|
|
|
name = models.CharField(max_length=100)
|
2022-02-03 20:24:19 +01:00
|
|
|
image = models.FileField(storage=temp_storage, upload_to="test_upload")
|
2015-07-22 09:43:21 -05:00
|
|
|
gallery = models.ForeignKey(Gallery, models.CASCADE, related_name="pictures")
|
2009-04-18 20:29:55 +00:00
|
|
|
|
|
|
|
|
2009-05-07 11:56:10 +00:00
|
|
|
class Language(models.Model):
|
|
|
|
iso = models.CharField(max_length=5, primary_key=True)
|
|
|
|
name = models.CharField(max_length=50)
|
|
|
|
english_name = models.CharField(max_length=50)
|
|
|
|
shortlist = models.BooleanField(default=False)
|
|
|
|
|
2020-01-18 19:03:03 +01:00
|
|
|
def __str__(self):
|
|
|
|
return self.iso
|
|
|
|
|
2009-05-07 11:56:10 +00:00
|
|
|
class Meta:
|
2022-02-03 20:24:19 +01:00
|
|
|
ordering = ("iso",)
|
2009-05-07 11:56:10 +00:00
|
|
|
|
|
|
|
|
2009-05-07 12:52:43 +00:00
|
|
|
# a base class for Recommender and Recommendation
|
|
|
|
class Title(models.Model):
|
|
|
|
pass
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2009-05-07 12:52:43 +00:00
|
|
|
class TitleTranslation(models.Model):
|
2015-07-22 09:43:21 -05:00
|
|
|
title = models.ForeignKey(Title, models.CASCADE)
|
2009-05-07 12:52:43 +00:00
|
|
|
text = models.CharField(max_length=100)
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2009-05-07 12:52:43 +00:00
|
|
|
class Recommender(Title):
|
|
|
|
pass
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2009-05-07 12:52:43 +00:00
|
|
|
class Recommendation(Title):
|
2016-08-05 16:19:09 +01:00
|
|
|
the_recommender = models.ForeignKey(Recommender, models.CASCADE)
|
2009-05-07 12:52:43 +00:00
|
|
|
|
|
|
|
|
2009-05-09 11:40:13 +00:00
|
|
|
class Collector(models.Model):
|
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2009-05-09 11:40:13 +00:00
|
|
|
class Widget(models.Model):
|
2015-07-22 09:43:21 -05:00
|
|
|
owner = models.ForeignKey(Collector, models.CASCADE)
|
2009-05-09 11:40:13 +00:00
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2009-05-09 11:40:13 +00:00
|
|
|
class DooHickey(models.Model):
|
|
|
|
code = models.CharField(max_length=10, primary_key=True)
|
2015-07-22 09:43:21 -05:00
|
|
|
owner = models.ForeignKey(Collector, models.CASCADE)
|
2009-05-09 11:40:13 +00:00
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2009-05-09 11:40:13 +00:00
|
|
|
class Grommet(models.Model):
|
|
|
|
code = models.AutoField(primary_key=True)
|
2015-07-22 09:43:21 -05:00
|
|
|
owner = models.ForeignKey(Collector, models.CASCADE)
|
2009-05-09 11:40:13 +00:00
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2009-05-09 11:40:13 +00:00
|
|
|
class Whatsit(models.Model):
|
|
|
|
index = models.IntegerField(primary_key=True)
|
2015-07-22 09:43:21 -05:00
|
|
|
owner = models.ForeignKey(Collector, models.CASCADE)
|
2009-05-09 11:40:13 +00:00
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2009-05-09 11:40:13 +00:00
|
|
|
class Doodad(models.Model):
|
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2009-05-09 11:40:13 +00:00
|
|
|
class FancyDoodad(Doodad):
|
2015-07-22 09:43:21 -05:00
|
|
|
owner = models.ForeignKey(Collector, models.CASCADE)
|
2009-05-09 11:40:13 +00:00
|
|
|
expensive = models.BooleanField(default=True)
|
|
|
|
|
|
|
|
|
2009-07-03 03:05:17 +00:00
|
|
|
class Category(models.Model):
|
2015-07-22 09:43:21 -05:00
|
|
|
collector = models.ForeignKey(Collector, models.CASCADE)
|
2009-07-03 03:05:17 +00:00
|
|
|
order = models.PositiveIntegerField()
|
|
|
|
|
|
|
|
class Meta:
|
2022-02-03 20:24:19 +01:00
|
|
|
ordering = ("order",)
|
2009-07-03 03:05:17 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2022-02-03 20:24:19 +01:00
|
|
|
return "%s:o%s" % (self.id, self.order)
|
2009-07-03 03:05:17 +00:00
|
|
|
|
2009-12-22 18:29:00 +00:00
|
|
|
|
2015-07-15 21:18:07 -04:00
|
|
|
def link_posted_default():
|
|
|
|
return datetime.date.today() - datetime.timedelta(days=7)
|
|
|
|
|
|
|
|
|
2009-12-22 18:29:00 +00:00
|
|
|
class Link(models.Model):
|
2015-07-15 21:18:07 -04:00
|
|
|
posted = models.DateField(default=link_posted_default)
|
2009-12-22 18:29:00 +00:00
|
|
|
url = models.URLField()
|
2015-07-22 09:43:21 -05:00
|
|
|
post = models.ForeignKey("Post", models.CASCADE)
|
2015-12-24 23:32:53 +02:00
|
|
|
readonly_link_content = models.TextField()
|
2009-12-22 18:29:00 +00:00
|
|
|
|
|
|
|
|
2011-04-22 12:02:25 +00:00
|
|
|
class PrePopulatedPost(models.Model):
|
|
|
|
title = models.CharField(max_length=100)
|
2013-08-11 21:19:09 +01:00
|
|
|
published = models.BooleanField(default=False)
|
2011-04-22 12:02:25 +00:00
|
|
|
slug = models.SlugField()
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2011-04-22 12:02:25 +00:00
|
|
|
class PrePopulatedSubPost(models.Model):
|
2015-07-22 09:43:21 -05:00
|
|
|
post = models.ForeignKey(PrePopulatedPost, models.CASCADE)
|
2011-04-22 12:02:25 +00:00
|
|
|
subtitle = models.CharField(max_length=100)
|
|
|
|
subslug = models.SlugField()
|
|
|
|
|
|
|
|
|
2009-12-22 18:29:00 +00:00
|
|
|
class Post(models.Model):
|
2022-02-03 20:24:19 +01:00
|
|
|
title = models.CharField(
|
|
|
|
max_length=100, help_text="Some help text for the title (with Unicode ŠĐĆŽćžšđ)"
|
|
|
|
)
|
|
|
|
content = models.TextField(
|
|
|
|
help_text="Some help text for the content (with Unicode ŠĐĆŽćžšđ)"
|
|
|
|
)
|
2015-12-24 23:32:53 +02:00
|
|
|
readonly_content = models.TextField()
|
2011-02-19 12:55:09 +00:00
|
|
|
posted = models.DateField(
|
2013-10-20 00:33:10 +01:00
|
|
|
default=datetime.date.today,
|
2022-02-03 20:24:19 +01:00
|
|
|
help_text="Some help text for the date (with Unicode ŠĐĆŽćžšđ)",
|
2011-02-19 12:55:09 +00:00
|
|
|
)
|
2017-05-06 10:56:28 -04:00
|
|
|
public = models.BooleanField(null=True, blank=True)
|
2009-12-22 18:29:00 +00:00
|
|
|
|
|
|
|
def awesomeness_level(self):
|
|
|
|
return "Very awesome."
|
|
|
|
|
2009-05-07 12:52:43 +00:00
|
|
|
|
2014-02-18 16:44:33 -06:00
|
|
|
# Proxy model to test overridden fields attrs on Post model so as not to
|
|
|
|
# interfere with other tests.
|
|
|
|
class FieldOverridePost(Post):
|
|
|
|
class Meta:
|
|
|
|
proxy = True
|
|
|
|
|
|
|
|
|
2009-12-18 10:08:05 +00:00
|
|
|
class Gadget(models.Model):
|
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2009-12-18 10:08:05 +00:00
|
|
|
return self.name
|
|
|
|
|
|
|
|
|
2010-02-26 13:17:43 +00:00
|
|
|
class Villain(models.Model):
|
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2010-02-26 13:17:43 +00:00
|
|
|
return self.name
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2010-02-26 13:17:43 +00:00
|
|
|
class SuperVillain(Villain):
|
|
|
|
pass
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2010-02-26 13:17:43 +00:00
|
|
|
class FunkyTag(models.Model):
|
|
|
|
"Because we all know there's only one real use case for GFKs."
|
|
|
|
name = models.CharField(max_length=25)
|
2015-07-22 09:43:21 -05:00
|
|
|
content_type = models.ForeignKey(ContentType, models.CASCADE)
|
2010-02-26 13:17:43 +00:00
|
|
|
object_id = models.PositiveIntegerField()
|
2022-02-03 20:24:19 +01:00
|
|
|
content_object = GenericForeignKey("content_type", "object_id")
|
2010-02-26 13:17:43 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2010-02-26 13:17:43 +00:00
|
|
|
return self.name
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2010-02-26 13:17:43 +00:00
|
|
|
class Plot(models.Model):
|
|
|
|
name = models.CharField(max_length=100)
|
2022-02-03 20:24:19 +01:00
|
|
|
team_leader = models.ForeignKey(Villain, models.CASCADE, related_name="lead_plots")
|
|
|
|
contact = models.ForeignKey(Villain, models.CASCADE, related_name="contact_plots")
|
2014-01-22 01:43:33 -05:00
|
|
|
tags = GenericRelation(FunkyTag)
|
2010-02-26 13:17:43 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2010-02-26 13:17:43 +00:00
|
|
|
return self.name
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2010-02-26 13:17:43 +00:00
|
|
|
class PlotDetails(models.Model):
|
|
|
|
details = models.CharField(max_length=100)
|
2016-01-09 22:15:21 +02:00
|
|
|
plot = models.OneToOneField(Plot, models.CASCADE, null=True, blank=True)
|
2010-02-26 13:17:43 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2010-02-26 13:17:43 +00:00
|
|
|
return self.details
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2016-01-09 22:15:21 +02:00
|
|
|
class PlotProxy(Plot):
|
|
|
|
class Meta:
|
|
|
|
proxy = True
|
|
|
|
|
|
|
|
|
2010-02-26 13:17:43 +00:00
|
|
|
class SecretHideout(models.Model):
|
2022-02-03 20:24:19 +01:00
|
|
|
"""Secret! Not registered with the admin!"""
|
|
|
|
|
2010-02-26 13:17:43 +00:00
|
|
|
location = models.CharField(max_length=100)
|
2015-07-22 09:43:21 -05:00
|
|
|
villain = models.ForeignKey(Villain, models.CASCADE)
|
2010-02-26 13:17:43 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2010-02-26 13:17:43 +00:00
|
|
|
return self.location
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2010-02-26 13:17:43 +00:00
|
|
|
class SuperSecretHideout(models.Model):
|
2022-02-03 20:24:19 +01:00
|
|
|
"""Secret! Not registered with the admin!"""
|
|
|
|
|
2010-02-26 13:17:43 +00:00
|
|
|
location = models.CharField(max_length=100)
|
2015-07-22 09:43:21 -05:00
|
|
|
supervillain = models.ForeignKey(SuperVillain, models.CASCADE)
|
2010-02-26 13:17:43 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2010-02-26 13:17:43 +00:00
|
|
|
return self.location
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2015-08-28 01:43:24 +05:30
|
|
|
class Bookmark(models.Model):
|
|
|
|
name = models.CharField(max_length=60)
|
2022-02-03 20:24:19 +01:00
|
|
|
tag = GenericRelation(FunkyTag, related_query_name="bookmark")
|
2015-08-28 01:43:24 +05:30
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
|
|
|
|
|
|
|
|
2010-02-26 13:17:43 +00:00
|
|
|
class CyclicOne(models.Model):
|
|
|
|
name = models.CharField(max_length=25)
|
2022-02-03 20:24:19 +01:00
|
|
|
two = models.ForeignKey("CyclicTwo", models.CASCADE)
|
2010-02-26 13:17:43 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2010-02-26 13:17:43 +00:00
|
|
|
return self.name
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2010-02-26 13:17:43 +00:00
|
|
|
class CyclicTwo(models.Model):
|
|
|
|
name = models.CharField(max_length=25)
|
2015-07-22 09:43:21 -05:00
|
|
|
one = models.ForeignKey(CyclicOne, models.CASCADE)
|
2010-02-26 13:17:43 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2010-02-26 13:17:43 +00:00
|
|
|
return self.name
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2010-03-21 14:23:25 +00:00
|
|
|
class Topping(models.Model):
|
2010-04-11 08:35:04 +00:00
|
|
|
name = models.CharField(max_length=20)
|
2010-03-21 14:23:25 +00:00
|
|
|
|
2016-09-11 08:19:56 -07:00
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2010-03-21 14:23:25 +00:00
|
|
|
class Pizza(models.Model):
|
|
|
|
name = models.CharField(max_length=20)
|
2022-02-03 20:24:19 +01:00
|
|
|
toppings = models.ManyToManyField("Topping", related_name="pizzas")
|
2010-03-21 14:23:25 +00:00
|
|
|
|
|
|
|
|
2017-04-05 13:54:46 +10:00
|
|
|
# Pizza's ModelAdmin has readonly_fields = ['toppings'].
|
|
|
|
# toppings is editable for this model's admin.
|
|
|
|
class ReadablePizza(Pizza):
|
|
|
|
class Meta:
|
|
|
|
proxy = True
|
|
|
|
|
|
|
|
|
2017-08-22 19:48:55 -04:00
|
|
|
# No default permissions are created for this model and both name and toppings
|
|
|
|
# are readonly for this model's admin.
|
|
|
|
class ReadOnlyPizza(Pizza):
|
|
|
|
class Meta:
|
|
|
|
proxy = True
|
|
|
|
default_permissions = ()
|
|
|
|
|
|
|
|
|
2010-08-06 14:58:05 +00:00
|
|
|
class Album(models.Model):
|
2015-07-22 09:43:21 -05:00
|
|
|
owner = models.ForeignKey(User, models.SET_NULL, null=True, blank=True)
|
2010-08-06 14:58:05 +00:00
|
|
|
title = models.CharField(max_length=30)
|
|
|
|
|
2010-12-23 03:44:38 +00:00
|
|
|
|
2016-10-10 16:23:35 +09:00
|
|
|
class Song(models.Model):
|
|
|
|
name = models.CharField(max_length=20)
|
|
|
|
album = models.ForeignKey(Album, on_delete=models.RESTRICT)
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
|
|
|
|
|
|
|
|
2011-01-12 23:30:47 +00:00
|
|
|
class Employee(Person):
|
|
|
|
code = models.CharField(max_length=20)
|
|
|
|
|
2021-03-18 11:21:23 +01:00
|
|
|
class Meta:
|
2022-02-03 20:24:19 +01:00
|
|
|
ordering = ["name"]
|
2021-03-18 11:21:23 +01:00
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2011-01-12 23:30:47 +00:00
|
|
|
class WorkHour(models.Model):
|
|
|
|
datum = models.DateField()
|
2015-07-22 09:43:21 -05:00
|
|
|
employee = models.ForeignKey(Employee, models.CASCADE)
|
2011-01-12 23:30:47 +00:00
|
|
|
|
|
|
|
|
2021-03-18 11:21:23 +01:00
|
|
|
class Manager(Employee):
|
|
|
|
"""
|
|
|
|
A multi-layer MTI child.
|
|
|
|
"""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
2021-03-18 11:21:23 +01:00
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
class Bonus(models.Model):
|
|
|
|
recipient = models.ForeignKey(Manager, on_delete=models.CASCADE)
|
|
|
|
|
|
|
|
|
2011-01-20 00:33:32 +00:00
|
|
|
class Question(models.Model):
|
2021-02-22 12:54:33 +01:00
|
|
|
big_id = models.BigAutoField(primary_key=True)
|
2011-01-20 00:33:32 +00:00
|
|
|
question = models.CharField(max_length=20)
|
2016-05-05 20:52:54 +03:00
|
|
|
posted = models.DateField(default=datetime.date.today)
|
2017-02-24 10:22:25 -05:00
|
|
|
expires = models.DateTimeField(null=True, blank=True)
|
2022-02-03 20:24:19 +01:00
|
|
|
related_questions = models.ManyToManyField("self")
|
2021-01-12 11:37:38 +01:00
|
|
|
uuid = models.UUIDField(default=uuid.uuid4, unique=True)
|
2017-05-10 14:48:57 +02:00
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.question
|
2011-01-20 00:33:32 +00:00
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2011-01-20 00:33:32 +00:00
|
|
|
class Answer(models.Model):
|
2015-07-22 09:43:21 -05:00
|
|
|
question = models.ForeignKey(Question, models.PROTECT)
|
2021-01-12 11:37:38 +01:00
|
|
|
question_with_to_field = models.ForeignKey(
|
2022-02-03 20:24:19 +01:00
|
|
|
Question,
|
|
|
|
models.SET_NULL,
|
|
|
|
blank=True,
|
|
|
|
null=True,
|
|
|
|
to_field="uuid",
|
|
|
|
related_name="uuid_answers",
|
|
|
|
limit_choices_to=~models.Q(question__istartswith="not"),
|
2021-01-12 11:37:38 +01:00
|
|
|
)
|
2022-02-03 20:24:19 +01:00
|
|
|
related_answers = models.ManyToManyField("self")
|
2011-01-20 00:33:32 +00:00
|
|
|
answer = models.CharField(max_length=20)
|
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2011-01-20 00:33:32 +00:00
|
|
|
return self.answer
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2017-02-24 10:22:25 -05:00
|
|
|
class Answer2(Answer):
|
|
|
|
class Meta:
|
|
|
|
proxy = True
|
|
|
|
|
|
|
|
|
2011-02-08 12:00:21 +00:00
|
|
|
class Reservation(models.Model):
|
|
|
|
start_date = models.DateTimeField()
|
|
|
|
price = models.IntegerField()
|
2011-02-19 11:48:42 +00:00
|
|
|
|
|
|
|
|
|
|
|
class FoodDelivery(models.Model):
|
2018-12-10 19:58:49 +05:30
|
|
|
DRIVER_CHOICES = (
|
2022-02-03 20:24:19 +01:00
|
|
|
("bill", "Bill G"),
|
|
|
|
("steve", "Steve J"),
|
2018-12-10 19:58:49 +05:30
|
|
|
)
|
|
|
|
RESTAURANT_CHOICES = (
|
2022-02-03 20:24:19 +01:00
|
|
|
("indian", "A Taste of India"),
|
|
|
|
("thai", "Thai Pography"),
|
|
|
|
("pizza", "Pizza Mama"),
|
2018-12-10 19:58:49 +05:30
|
|
|
)
|
2011-02-19 11:48:42 +00:00
|
|
|
reference = models.CharField(max_length=100)
|
|
|
|
driver = models.CharField(max_length=100, choices=DRIVER_CHOICES, blank=True)
|
2022-02-03 20:24:19 +01:00
|
|
|
restaurant = models.CharField(
|
|
|
|
max_length=100, choices=RESTAURANT_CHOICES, blank=True
|
|
|
|
)
|
2011-02-19 11:48:42 +00:00
|
|
|
|
|
|
|
class Meta:
|
|
|
|
unique_together = (("driver", "restaurant"),)
|
|
|
|
|
|
|
|
|
2012-12-24 16:17:16 -03:00
|
|
|
class CoverLetter(models.Model):
|
|
|
|
author = models.CharField(max_length=30)
|
|
|
|
date_written = models.DateField(null=True, blank=True)
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.author
|
|
|
|
|
|
|
|
|
2011-02-20 23:09:25 +00:00
|
|
|
class Paper(models.Model):
|
|
|
|
title = models.CharField(max_length=30)
|
|
|
|
author = models.CharField(max_length=30, blank=True, null=True)
|
|
|
|
|
2011-09-20 18:16:49 +00:00
|
|
|
|
2012-12-24 16:17:16 -03:00
|
|
|
class ShortMessage(models.Model):
|
|
|
|
content = models.CharField(max_length=140)
|
|
|
|
timestamp = models.DateTimeField(null=True, blank=True)
|
|
|
|
|
|
|
|
|
|
|
|
class Telegram(models.Model):
|
|
|
|
title = models.CharField(max_length=30)
|
|
|
|
date_sent = models.DateField(null=True, blank=True)
|
2011-02-20 23:09:25 +00:00
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2012-12-24 16:17:16 -03:00
|
|
|
return self.title
|
2011-02-20 23:09:25 +00:00
|
|
|
|
|
|
|
|
2011-03-03 13:20:45 +00:00
|
|
|
class Story(models.Model):
|
|
|
|
title = models.CharField(max_length=100)
|
|
|
|
content = models.TextField()
|
|
|
|
|
|
|
|
|
|
|
|
class OtherStory(models.Model):
|
|
|
|
title = models.CharField(max_length=100)
|
|
|
|
content = models.TextField()
|
|
|
|
|
2011-02-19 11:48:42 +00:00
|
|
|
|
2011-06-03 11:54:29 +00:00
|
|
|
class ComplexSortedPerson(models.Model):
|
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
age = models.PositiveIntegerField()
|
2017-05-06 10:56:28 -04:00
|
|
|
is_employee = models.BooleanField(null=True)
|
2011-06-03 11:54:29 +00:00
|
|
|
|
2013-05-19 10:52:29 +02:00
|
|
|
|
|
|
|
class PluggableSearchPerson(models.Model):
|
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
age = models.PositiveIntegerField()
|
|
|
|
|
|
|
|
|
2011-11-22 09:14:09 +00:00
|
|
|
class PrePopulatedPostLargeSlug(models.Model):
|
|
|
|
"""
|
|
|
|
Regression test for #15938: a large max_length for the slugfield must not
|
|
|
|
be localized in prepopulated_fields_js.html or it might end up breaking
|
2021-04-29 19:29:08 +01:00
|
|
|
the JavaScript (ie, using THOUSAND_SEPARATOR ends up with maxLength=1,000)
|
2011-11-22 09:14:09 +00:00
|
|
|
"""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
2011-11-22 09:14:09 +00:00
|
|
|
title = models.CharField(max_length=100)
|
2013-08-11 21:19:09 +01:00
|
|
|
published = models.BooleanField(default=False)
|
2014-10-19 02:27:31 +02:00
|
|
|
# `db_index=False` because MySQL cannot index large CharField (#21196).
|
|
|
|
slug = models.SlugField(max_length=1000, db_index=False)
|
2011-11-22 09:14:09 +00:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2011-11-22 09:14:09 +00:00
|
|
|
class AdminOrderedField(models.Model):
|
|
|
|
order = models.IntegerField()
|
|
|
|
stuff = models.CharField(max_length=200)
|
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2011-11-22 09:14:09 +00:00
|
|
|
class AdminOrderedModelMethod(models.Model):
|
|
|
|
order = models.IntegerField()
|
|
|
|
stuff = models.CharField(max_length=200)
|
2013-10-22 11:21:07 +01:00
|
|
|
|
2022-02-03 20:24:19 +01:00
|
|
|
@admin.display(ordering="order")
|
2011-11-22 09:14:09 +00:00
|
|
|
def some_order(self):
|
|
|
|
return self.order
|
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2011-11-22 09:14:09 +00:00
|
|
|
class AdminOrderedAdminMethod(models.Model):
|
|
|
|
order = models.IntegerField()
|
|
|
|
stuff = models.CharField(max_length=200)
|
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2011-11-22 09:14:09 +00:00
|
|
|
class AdminOrderedCallable(models.Model):
|
|
|
|
order = models.IntegerField()
|
|
|
|
stuff = models.CharField(max_length=200)
|
2011-12-19 14:59:14 +00:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2011-12-19 14:59:14 +00:00
|
|
|
class Report(models.Model):
|
|
|
|
title = models.CharField(max_length=100)
|
|
|
|
|
2012-08-12 12:32:08 +02:00
|
|
|
def __str__(self):
|
2011-12-19 14:59:14 +00:00
|
|
|
return self.title
|
2012-02-19 16:42:12 +00:00
|
|
|
|
|
|
|
|
|
|
|
class MainPrepopulated(models.Model):
|
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
pubdate = models.DateField()
|
|
|
|
status = models.CharField(
|
|
|
|
max_length=20,
|
2022-02-03 20:24:19 +01:00
|
|
|
choices=(("option one", "Option One"), ("option two", "Option Two")),
|
|
|
|
)
|
2013-07-30 00:21:08 -07:00
|
|
|
slug1 = models.SlugField(blank=True)
|
|
|
|
slug2 = models.SlugField(blank=True)
|
2015-04-15 16:28:49 -06:00
|
|
|
slug3 = models.SlugField(blank=True, allow_unicode=True)
|
2012-02-19 16:42:12 +00:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2012-02-19 16:42:12 +00:00
|
|
|
class RelatedPrepopulated(models.Model):
|
2015-07-22 09:43:21 -05:00
|
|
|
parent = models.ForeignKey(MainPrepopulated, models.CASCADE)
|
2012-02-19 16:42:12 +00:00
|
|
|
name = models.CharField(max_length=75)
|
2022-02-03 20:24:19 +01:00
|
|
|
fk = models.ForeignKey("self", models.CASCADE, blank=True, null=True)
|
|
|
|
m2m = models.ManyToManyField("self", blank=True)
|
2012-02-19 16:42:12 +00:00
|
|
|
pubdate = models.DateField()
|
|
|
|
status = models.CharField(
|
|
|
|
max_length=20,
|
2022-02-03 20:24:19 +01:00
|
|
|
choices=(("option one", "Option One"), ("option two", "Option Two")),
|
|
|
|
)
|
2012-02-19 16:42:12 +00:00
|
|
|
slug1 = models.SlugField(max_length=50)
|
2012-03-03 02:13:35 +00:00
|
|
|
slug2 = models.SlugField(max_length=60)
|
|
|
|
|
|
|
|
|
|
|
|
class UnorderedObject(models.Model):
|
|
|
|
"""
|
|
|
|
Model without any defined `Meta.ordering`.
|
|
|
|
Refs #16819.
|
|
|
|
"""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
2012-03-03 02:13:35 +00:00
|
|
|
name = models.CharField(max_length=255)
|
|
|
|
bool = models.BooleanField(default=True)
|
2012-07-21 18:10:24 -07:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2012-07-21 18:10:24 -07:00
|
|
|
class UndeletableObject(models.Model):
|
|
|
|
"""
|
|
|
|
Model whose show_delete in admin change_view has been disabled
|
|
|
|
Refs #10057.
|
|
|
|
"""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
2012-07-21 18:10:24 -07:00
|
|
|
name = models.CharField(max_length=255)
|
2012-09-08 11:18:08 -04:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2013-08-18 00:05:13 +02:00
|
|
|
class UnchangeableObject(models.Model):
|
|
|
|
"""
|
|
|
|
Model whose change_view is disabled in admin
|
|
|
|
Refs #20640.
|
|
|
|
"""
|
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2012-11-17 22:53:31 +01:00
|
|
|
class UserMessenger(models.Model):
|
|
|
|
"""
|
|
|
|
Dummy class for testing message_user functions on ModelAdmin
|
|
|
|
"""
|
2012-09-08 11:18:08 -04:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2012-09-08 11:18:08 -04:00
|
|
|
class Simple(models.Model):
|
|
|
|
"""
|
|
|
|
Simple model with nothing on it for use in testing
|
|
|
|
"""
|
2012-11-25 23:13:22 +01:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2012-11-25 23:13:22 +01:00
|
|
|
class Choice(models.Model):
|
2016-04-07 22:04:45 -04:00
|
|
|
choice = models.IntegerField(
|
2022-02-03 20:24:19 +01:00
|
|
|
blank=True,
|
|
|
|
null=True,
|
|
|
|
choices=((1, "Yes"), (0, "No"), (None, "No opinion")),
|
2016-04-07 22:04:45 -04:00
|
|
|
)
|
2013-09-06 20:28:48 +00:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2013-11-14 19:26:19 -07:00
|
|
|
class ParentWithDependentChildren(models.Model):
|
|
|
|
"""
|
|
|
|
Issue #20522
|
|
|
|
Model where the validation of child foreign-key relationships depends
|
|
|
|
on validation of the parent
|
|
|
|
"""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
2013-11-14 19:26:19 -07:00
|
|
|
some_required_info = models.PositiveIntegerField()
|
|
|
|
family_name = models.CharField(max_length=255, blank=False)
|
|
|
|
|
|
|
|
|
|
|
|
class DependentChild(models.Model):
|
|
|
|
"""
|
|
|
|
Issue #20522
|
|
|
|
Model that depends on validation of the parent class for one of its
|
|
|
|
fields to validate during clean
|
|
|
|
"""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
2015-07-22 09:43:21 -05:00
|
|
|
parent = models.ForeignKey(ParentWithDependentChildren, models.CASCADE)
|
2013-11-14 19:26:19 -07:00
|
|
|
family_name = models.CharField(max_length=255)
|
|
|
|
|
|
|
|
|
2013-09-06 20:28:48 +00:00
|
|
|
class _Manager(models.Manager):
|
|
|
|
def get_queryset(self):
|
2017-01-21 18:43:44 +05:30
|
|
|
return super().get_queryset().filter(pk__gt=1)
|
2013-09-06 20:28:48 +00:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2013-09-06 20:28:48 +00:00
|
|
|
class FilteredManager(models.Model):
|
|
|
|
def __str__(self):
|
|
|
|
return "PK=%d" % self.pk
|
|
|
|
|
|
|
|
pk_gt_1 = _Manager()
|
|
|
|
objects = models.Manager()
|
2013-02-23 18:57:48 +01:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2013-02-23 18:57:48 +01:00
|
|
|
class EmptyModelVisible(models.Model):
|
2022-02-03 20:24:19 +01:00
|
|
|
"""See ticket #11277."""
|
2013-02-23 18:57:48 +01:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2013-02-23 18:57:48 +01:00
|
|
|
class EmptyModelHidden(models.Model):
|
2022-02-03 20:24:19 +01:00
|
|
|
"""See ticket #11277."""
|
2013-02-23 18:57:48 +01:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2013-02-23 18:57:48 +01:00
|
|
|
class EmptyModelMixin(models.Model):
|
2022-02-03 20:24:19 +01:00
|
|
|
"""See ticket #11277."""
|
2013-10-24 17:28:09 +02:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2013-10-24 17:28:09 +02:00
|
|
|
class State(models.Model):
|
2022-02-03 20:24:19 +01:00
|
|
|
name = models.CharField(max_length=100, verbose_name="State verbose_name")
|
2013-10-24 17:28:09 +02:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2013-10-24 17:28:09 +02:00
|
|
|
class City(models.Model):
|
2015-07-22 09:43:21 -05:00
|
|
|
state = models.ForeignKey(State, models.CASCADE)
|
2022-02-03 20:24:19 +01:00
|
|
|
name = models.CharField(max_length=100, verbose_name="City verbose_name")
|
2013-10-24 17:28:09 +02:00
|
|
|
|
2013-11-21 16:26:49 +07:00
|
|
|
def get_absolute_url(self):
|
2022-02-03 20:24:19 +01:00
|
|
|
return "/dummy/%s/" % self.pk
|
2013-11-21 16:26:49 +07:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2013-10-24 17:28:09 +02:00
|
|
|
class Restaurant(models.Model):
|
2015-07-22 09:43:21 -05:00
|
|
|
city = models.ForeignKey(City, models.CASCADE)
|
2013-10-24 17:28:09 +02:00
|
|
|
name = models.CharField(max_length=100)
|
|
|
|
|
2013-11-21 16:26:49 +07:00
|
|
|
def get_absolute_url(self):
|
2022-02-03 20:24:19 +01:00
|
|
|
return "/dummy/%s/" % self.pk
|
2013-11-21 16:26:49 +07:00
|
|
|
|
2013-11-02 23:36:09 -05:00
|
|
|
|
2013-10-24 17:28:09 +02:00
|
|
|
class Worker(models.Model):
|
2015-07-22 09:43:21 -05:00
|
|
|
work_at = models.ForeignKey(Restaurant, models.CASCADE)
|
2013-10-24 17:28:09 +02:00
|
|
|
name = models.CharField(max_length=50)
|
|
|
|
surname = models.CharField(max_length=50)
|
2014-08-21 11:55:23 -04:00
|
|
|
|
|
|
|
|
|
|
|
# Models for #23329
|
|
|
|
class ReferencedByParent(models.Model):
|
2014-11-16 16:42:09 +01:00
|
|
|
name = models.CharField(max_length=20, unique=True)
|
2014-08-21 11:55:23 -04:00
|
|
|
|
|
|
|
|
|
|
|
class ParentWithFK(models.Model):
|
2014-11-16 16:42:09 +01:00
|
|
|
fk = models.ForeignKey(
|
2015-07-22 09:43:21 -05:00
|
|
|
ReferencedByParent,
|
|
|
|
models.CASCADE,
|
2022-02-03 20:24:19 +01:00
|
|
|
to_field="name",
|
|
|
|
related_name="hidden+",
|
2014-11-16 16:42:09 +01:00
|
|
|
)
|
2014-08-21 11:55:23 -04:00
|
|
|
|
|
|
|
|
|
|
|
class ChildOfReferer(ParentWithFK):
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
2014-09-04 17:04:53 -04:00
|
|
|
# Models for #23431
|
2016-08-05 15:20:38 +01:00
|
|
|
class InlineReferer(models.Model):
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
2014-09-04 17:04:53 -04:00
|
|
|
class ReferencedByInline(models.Model):
|
2014-11-16 16:42:09 +01:00
|
|
|
name = models.CharField(max_length=20, unique=True)
|
2014-09-04 17:04:53 -04:00
|
|
|
|
|
|
|
|
|
|
|
class InlineReference(models.Model):
|
2016-08-05 15:20:38 +01:00
|
|
|
referer = models.ForeignKey(InlineReferer, models.CASCADE)
|
2014-11-16 16:42:09 +01:00
|
|
|
fk = models.ForeignKey(
|
2015-07-22 09:43:21 -05:00
|
|
|
ReferencedByInline,
|
|
|
|
models.CASCADE,
|
2022-02-03 20:24:19 +01:00
|
|
|
to_field="name",
|
|
|
|
related_name="hidden+",
|
2014-11-16 16:42:09 +01:00
|
|
|
)
|
2014-09-04 17:04:53 -04:00
|
|
|
|
|
|
|
|
2014-10-05 20:06:51 +02:00
|
|
|
class Recipe(models.Model):
|
2014-11-25 14:27:46 -05:00
|
|
|
rname = models.CharField(max_length=20, unique=True)
|
2014-10-05 20:06:51 +02:00
|
|
|
|
|
|
|
|
|
|
|
class Ingredient(models.Model):
|
2014-11-25 14:27:46 -05:00
|
|
|
iname = models.CharField(max_length=20, unique=True)
|
2022-02-03 20:24:19 +01:00
|
|
|
recipes = models.ManyToManyField(Recipe, through="RecipeIngredient")
|
2014-11-25 14:27:46 -05:00
|
|
|
|
|
|
|
|
|
|
|
class RecipeIngredient(models.Model):
|
2022-02-03 20:24:19 +01:00
|
|
|
ingredient = models.ForeignKey(Ingredient, models.CASCADE, to_field="iname")
|
|
|
|
recipe = models.ForeignKey(Recipe, models.CASCADE, to_field="rname")
|
2014-11-16 16:42:09 +01:00
|
|
|
|
|
|
|
|
|
|
|
# Model for #23839
|
|
|
|
class NotReferenced(models.Model):
|
|
|
|
# Don't point any FK at this model.
|
|
|
|
pass
|
2014-11-27 19:34:14 +01:00
|
|
|
|
|
|
|
|
|
|
|
# Models for #23934
|
|
|
|
class ExplicitlyProvidedPK(models.Model):
|
|
|
|
name = models.IntegerField(primary_key=True)
|
|
|
|
|
|
|
|
|
|
|
|
class ImplicitlyGeneratedPK(models.Model):
|
|
|
|
name = models.IntegerField(unique=True)
|
2015-10-28 11:25:25 -04:00
|
|
|
|
|
|
|
|
|
|
|
# Models for #25622
|
|
|
|
class ReferencedByGenRel(models.Model):
|
|
|
|
content_type = models.ForeignKey(ContentType, on_delete=models.CASCADE)
|
|
|
|
object_id = models.PositiveIntegerField()
|
2022-02-03 20:24:19 +01:00
|
|
|
content_object = GenericForeignKey("content_type", "object_id")
|
2015-10-28 11:25:25 -04:00
|
|
|
|
|
|
|
|
|
|
|
class GenRelReference(models.Model):
|
|
|
|
references = GenericRelation(ReferencedByGenRel)
|
2016-01-07 11:07:15 +02:00
|
|
|
|
|
|
|
|
|
|
|
class ParentWithUUIDPK(models.Model):
|
|
|
|
id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
|
|
|
|
title = models.CharField(max_length=100)
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return str(self.id)
|
|
|
|
|
|
|
|
|
|
|
|
class RelatedWithUUIDPKModel(models.Model):
|
2022-02-03 20:24:19 +01:00
|
|
|
parent = models.ForeignKey(
|
|
|
|
ParentWithUUIDPK, on_delete=models.SET_NULL, null=True, blank=True
|
|
|
|
)
|
2017-05-10 14:48:57 +02:00
|
|
|
|
|
|
|
|
|
|
|
class Author(models.Model):
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
class Authorship(models.Model):
|
|
|
|
book = models.ForeignKey(Book, models.CASCADE)
|
|
|
|
author = models.ForeignKey(Author, models.CASCADE)
|
2019-01-16 16:07:28 +01:00
|
|
|
|
|
|
|
|
|
|
|
class UserProxy(User):
|
|
|
|
"""Proxy a model with a different app_label."""
|
2022-02-03 20:24:19 +01:00
|
|
|
|
2019-01-16 16:07:28 +01:00
|
|
|
class Meta:
|
|
|
|
proxy = True
|
2020-01-18 19:03:03 +01:00
|
|
|
|
|
|
|
|
|
|
|
class ReadOnlyRelatedField(models.Model):
|
|
|
|
chapter = models.ForeignKey(Chapter, models.CASCADE)
|
|
|
|
language = models.ForeignKey(Language, models.CASCADE)
|
|
|
|
user = models.ForeignKey(User, models.CASCADE)
|
2021-08-26 17:43:40 +02:00
|
|
|
|
|
|
|
|
|
|
|
class Héllo(models.Model):
|
|
|
|
pass
|
2021-09-01 17:31:40 +05:30
|
|
|
|
|
|
|
|
|
|
|
class Box(models.Model):
|
|
|
|
title = models.CharField(max_length=100)
|
2022-02-03 20:24:19 +01:00
|
|
|
next_box = models.ForeignKey(
|
|
|
|
"self", null=True, on_delete=models.SET_NULL, blank=True
|
|
|
|
)
|
|
|
|
next_box = models.ForeignKey(
|
|
|
|
"self", null=True, on_delete=models.SET_NULL, blank=True
|
|
|
|
)
|
2022-04-13 15:27:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
class Country(models.Model):
|
|
|
|
NORTH_AMERICA = "North America"
|
|
|
|
SOUTH_AMERICA = "South America"
|
|
|
|
EUROPE = "Europe"
|
|
|
|
ASIA = "Asia"
|
|
|
|
OCEANIA = "Oceania"
|
|
|
|
ANTARCTICA = "Antarctica"
|
|
|
|
|
|
|
|
CONTINENT_CHOICES = [
|
|
|
|
(NORTH_AMERICA, NORTH_AMERICA),
|
|
|
|
(SOUTH_AMERICA, SOUTH_AMERICA),
|
|
|
|
(EUROPE, EUROPE),
|
|
|
|
(ASIA, ASIA),
|
|
|
|
(OCEANIA, OCEANIA),
|
|
|
|
(ANTARCTICA, ANTARCTICA),
|
|
|
|
]
|
|
|
|
name = models.CharField(max_length=80)
|
|
|
|
continent = models.CharField(max_length=13, choices=CONTINENT_CHOICES)
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
|
|
|
|
|
|
|
|
|
|
|
class Traveler(models.Model):
|
|
|
|
born_country = models.ForeignKey(Country, models.CASCADE)
|
|
|
|
living_country = models.ForeignKey(
|
|
|
|
Country, models.CASCADE, related_name="living_country_set"
|
|
|
|
)
|
|
|
|
favorite_country_to_vacation = models.ForeignKey(
|
|
|
|
Country,
|
|
|
|
models.CASCADE,
|
|
|
|
related_name="favorite_country_to_vacation_set",
|
|
|
|
limit_choices_to={"continent": Country.ASIA},
|
|
|
|
)
|
2023-09-15 15:30:06 +02:00
|
|
|
|
|
|
|
|
|
|
|
class Square(models.Model):
|
|
|
|
side = models.IntegerField()
|
|
|
|
area = models.GeneratedField(
|
|
|
|
db_persist=True,
|
|
|
|
expression=models.F("side") * models.F("side"),
|
2023-11-13 05:33:25 +01:00
|
|
|
output_field=models.BigIntegerField(),
|
2023-09-15 15:30:06 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
required_db_features = {"supports_stored_generated_columns"}
|
2024-04-02 18:00:25 -07:00
|
|
|
|
|
|
|
|
|
|
|
class CamelCaseModel(models.Model):
|
|
|
|
interesting_name = models.CharField(max_length=100)
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.interesting_name
|
|
|
|
|
|
|
|
|
|
|
|
class CamelCaseRelatedModel(models.Model):
|
|
|
|
m2m = models.ManyToManyField(CamelCaseModel, related_name="m2m")
|
|
|
|
fk = models.ForeignKey(CamelCaseModel, on_delete=models.CASCADE, related_name="fk")
|