Development of an internal social media platform with personalised dashboards for students
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

0001_initial.py 4.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. import django.contrib.auth.models
  2. from django.contrib.auth import validators
  3. from django.db import migrations, models
  4. from django.utils import timezone
  5. class Migration(migrations.Migration):
  6. dependencies = [
  7. ('contenttypes', '__first__'),
  8. ]
  9. operations = [
  10. migrations.CreateModel(
  11. name='Permission',
  12. fields=[
  13. ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)),
  14. ('name', models.CharField(max_length=50, verbose_name='name')),
  15. ('content_type', models.ForeignKey(
  16. to='contenttypes.ContentType',
  17. on_delete=models.CASCADE,
  18. to_field='id',
  19. verbose_name='content type',
  20. )),
  21. ('codename', models.CharField(max_length=100, verbose_name='codename')),
  22. ],
  23. options={
  24. 'ordering': ('content_type__app_label', 'content_type__model', 'codename'),
  25. 'unique_together': {('content_type', 'codename')},
  26. 'verbose_name': 'permission',
  27. 'verbose_name_plural': 'permissions',
  28. },
  29. managers=[
  30. ('objects', django.contrib.auth.models.PermissionManager()),
  31. ],
  32. ),
  33. migrations.CreateModel(
  34. name='Group',
  35. fields=[
  36. ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)),
  37. ('name', models.CharField(unique=True, max_length=80, verbose_name='name')),
  38. ('permissions', models.ManyToManyField(to='auth.Permission', verbose_name='permissions', blank=True)),
  39. ],
  40. options={
  41. 'verbose_name': 'group',
  42. 'verbose_name_plural': 'groups',
  43. },
  44. managers=[
  45. ('objects', django.contrib.auth.models.GroupManager()),
  46. ],
  47. ),
  48. migrations.CreateModel(
  49. name='User',
  50. fields=[
  51. ('id', models.AutoField(verbose_name='ID', serialize=False, auto_created=True, primary_key=True)),
  52. ('password', models.CharField(max_length=128, verbose_name='password')),
  53. ('last_login', models.DateTimeField(default=timezone.now, verbose_name='last login')),
  54. ('is_superuser', models.BooleanField(
  55. default=False,
  56. help_text='Designates that this user has all permissions without explicitly assigning them.',
  57. verbose_name='superuser status'
  58. )),
  59. ('username', models.CharField(
  60. help_text='Required. 30 characters or fewer. Letters, digits and @/./+/-/_ only.', unique=True,
  61. max_length=30, verbose_name='username',
  62. validators=[validators.UnicodeUsernameValidator()],
  63. )),
  64. ('first_name', models.CharField(max_length=30, verbose_name='first name', blank=True)),
  65. ('last_name', models.CharField(max_length=30, verbose_name='last name', blank=True)),
  66. ('email', models.EmailField(max_length=75, verbose_name='email address', blank=True)),
  67. ('is_staff', models.BooleanField(
  68. default=False, help_text='Designates whether the user can log into this admin site.',
  69. verbose_name='staff status'
  70. )),
  71. ('is_active', models.BooleanField(
  72. default=True, verbose_name='active', help_text=(
  73. 'Designates whether this user should be treated as active. Unselect this instead of deleting '
  74. 'accounts.'
  75. )
  76. )),
  77. ('date_joined', models.DateTimeField(default=timezone.now, verbose_name='date joined')),
  78. ('groups', models.ManyToManyField(
  79. to='auth.Group', verbose_name='groups', blank=True, related_name='user_set',
  80. related_query_name='user', help_text=(
  81. 'The groups this user belongs to. A user will get all permissions granted to each of their '
  82. 'groups.'
  83. )
  84. )),
  85. ('user_permissions', models.ManyToManyField(
  86. to='auth.Permission', verbose_name='user permissions', blank=True,
  87. help_text='Specific permissions for this user.', related_name='user_set',
  88. related_query_name='user')
  89. ),
  90. ],
  91. options={
  92. 'swappable': 'AUTH_USER_MODEL',
  93. 'verbose_name': 'user',
  94. 'verbose_name_plural': 'users',
  95. },
  96. managers=[
  97. ('objects', django.contrib.auth.models.UserManager()),
  98. ],
  99. ),
  100. ]