models.py 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. from datetime import datetime
  2. from django.core.exceptions import ValidationError
  3. from django.db import models
  4. from django.db.models.functions import Lower
  5. def validate_answer_to_universe(value):
  6. if value != 42:
  7. raise ValidationError('This is not the answer to life, universe and everything!', code='not42')
  8. class ModelToValidate(models.Model):
  9. name = models.CharField(max_length=100)
  10. created = models.DateTimeField(default=datetime.now)
  11. number = models.IntegerField(db_column='number_val')
  12. parent = models.ForeignKey(
  13. 'self',
  14. models.SET_NULL,
  15. blank=True, null=True,
  16. limit_choices_to={'number': 10},
  17. )
  18. email = models.EmailField(blank=True)
  19. ufm = models.ForeignKey(
  20. 'UniqueFieldsModel',
  21. models.SET_NULL,
  22. to_field='unique_charfield',
  23. blank=True, null=True,
  24. )
  25. url = models.URLField(blank=True)
  26. f_with_custom_validator = models.IntegerField(blank=True, null=True, validators=[validate_answer_to_universe])
  27. f_with_iterable_of_validators = models.IntegerField(blank=True, null=True,
  28. validators=(validate_answer_to_universe,))
  29. slug = models.SlugField(blank=True)
  30. def clean(self):
  31. super().clean()
  32. if self.number == 11:
  33. raise ValidationError('Invalid number supplied!')
  34. class UniqueFieldsModel(models.Model):
  35. unique_charfield = models.CharField(max_length=100, unique=True)
  36. unique_integerfield = models.IntegerField(unique=True)
  37. non_unique_field = models.IntegerField()
  38. class CustomPKModel(models.Model):
  39. my_pk_field = models.CharField(max_length=100, primary_key=True)
  40. class UniqueTogetherModel(models.Model):
  41. cfield = models.CharField(max_length=100)
  42. ifield = models.IntegerField()
  43. efield = models.EmailField()
  44. class Meta:
  45. unique_together = (('ifield', 'cfield',), ['ifield', 'efield'])
  46. class UniqueForDateModel(models.Model):
  47. start_date = models.DateField()
  48. end_date = models.DateTimeField()
  49. count = models.IntegerField(unique_for_date="start_date", unique_for_year="end_date")
  50. order = models.IntegerField(unique_for_month="end_date")
  51. name = models.CharField(max_length=100)
  52. class CustomMessagesModel(models.Model):
  53. other = models.IntegerField(blank=True, null=True)
  54. number = models.IntegerField(
  55. db_column='number_val',
  56. error_messages={'null': 'NULL', 'not42': 'AAARGH', 'not_equal': '%s != me'},
  57. validators=[validate_answer_to_universe]
  58. )
  59. class AuthorManager(models.Manager):
  60. def get_queryset(self):
  61. qs = super().get_queryset()
  62. return qs.filter(archived=False)
  63. class Author(models.Model):
  64. name = models.CharField(max_length=100)
  65. archived = models.BooleanField(default=False)
  66. objects = AuthorManager()
  67. class Article(models.Model):
  68. title = models.CharField(max_length=100)
  69. author = models.ForeignKey(Author, models.CASCADE)
  70. pub_date = models.DateTimeField(blank=True)
  71. def clean(self):
  72. if self.pub_date is None:
  73. self.pub_date = datetime.now()
  74. class Post(models.Model):
  75. title = models.CharField(max_length=50, unique_for_date='posted', blank=True)
  76. slug = models.CharField(max_length=50, unique_for_year='posted', blank=True)
  77. subtitle = models.CharField(max_length=50, unique_for_month='posted', blank=True)
  78. posted = models.DateField()
  79. class FlexibleDatePost(models.Model):
  80. title = models.CharField(max_length=50, unique_for_date='posted', blank=True)
  81. slug = models.CharField(max_length=50, unique_for_year='posted', blank=True)
  82. subtitle = models.CharField(max_length=50, unique_for_month='posted', blank=True)
  83. posted = models.DateField(blank=True, null=True)
  84. class UniqueErrorsModel(models.Model):
  85. name = models.CharField(max_length=100, unique=True, error_messages={'unique': 'Custom unique name message.'})
  86. no = models.IntegerField(unique=True, error_messages={'unique': 'Custom unique number message.'})
  87. class GenericIPAddressTestModel(models.Model):
  88. generic_ip = models.GenericIPAddressField(blank=True, null=True, unique=True)
  89. v4_ip = models.GenericIPAddressField(blank=True, null=True, protocol="ipv4")
  90. v6_ip = models.GenericIPAddressField(blank=True, null=True, protocol="ipv6")
  91. ip_verbose_name = models.GenericIPAddressField("IP Address Verbose", blank=True, null=True)
  92. class GenericIPAddrUnpackUniqueTest(models.Model):
  93. generic_v4unpack_ip = models.GenericIPAddressField(null=True, blank=True, unique=True, unpack_ipv4=True)
  94. class UniqueFuncConstraintModel(models.Model):
  95. field = models.CharField(max_length=255)
  96. class Meta:
  97. required_db_features = {'supports_expression_indexes'}
  98. constraints = [
  99. models.UniqueConstraint(Lower('field'), name='func_lower_field_uq'),
  100. ]