authentik/passbook/core/migrations/0001_initial.py

339 lines
12 KiB
Python
Raw Normal View History

# Generated by Django 3.0.6 on 2020-05-19 22:07
2019-02-08 14:19:29 +00:00
import uuid
2018-11-11 12:41:48 +00:00
import django.contrib.auth.models
import django.contrib.auth.validators
import django.db.models.deletion
import django.utils.timezone
import guardian.mixins
2019-02-08 14:19:29 +00:00
from django.conf import settings
from django.db import migrations, models
2018-11-11 12:41:48 +00:00
2019-10-07 15:33:48 +01:00
import passbook.core.models
2018-11-11 12:41:48 +00:00
class Migration(migrations.Migration):
initial = True
dependencies = [
("passbook_policies", "0001_initial"),
("auth", "0011_update_proxy_permissions"),
2018-11-11 12:41:48 +00:00
]
operations = [
migrations.CreateModel(
2019-12-31 11:51:16 +00:00
name="User",
2018-11-11 12:41:48 +00:00
fields=[
2019-12-31 11:51:16 +00:00
(
"id",
models.AutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("password", models.CharField(max_length=128, verbose_name="password")),
(
"last_login",
models.DateTimeField(
blank=True, null=True, verbose_name="last login"
),
),
(
"is_superuser",
models.BooleanField(
default=False,
help_text="Designates that this user has all permissions without explicitly assigning them.",
verbose_name="superuser status",
),
),
(
"username",
models.CharField(
error_messages={
"unique": "A user with that username already exists."
},
help_text="Required. 150 characters or fewer. Letters, digits and @/./+/-/_ only.",
max_length=150,
unique=True,
validators=[
django.contrib.auth.validators.UnicodeUsernameValidator()
],
verbose_name="username",
),
),
(
"first_name",
models.CharField(
blank=True, max_length=30, verbose_name="first name"
),
),
(
"last_name",
models.CharField(
blank=True, max_length=150, verbose_name="last name"
),
),
(
"email",
models.EmailField(
blank=True, max_length=254, verbose_name="email address"
),
),
(
"is_staff",
models.BooleanField(
default=False,
help_text="Designates whether the user can log into this admin site.",
verbose_name="staff status",
),
),
(
"is_active",
models.BooleanField(
default=True,
help_text="Designates whether this user should be treated as active. Unselect this instead of deleting accounts.",
verbose_name="active",
),
),
(
"date_joined",
models.DateTimeField(
default=django.utils.timezone.now, verbose_name="date joined"
),
),
("uuid", models.UUIDField(default=uuid.uuid4, editable=False)),
("name", models.TextField(help_text="User's display name.")),
2019-12-31 11:51:16 +00:00
("password_change_date", models.DateTimeField(auto_now_add=True)),
2020-08-15 20:04:22 +01:00
("attributes", models.JSONField(blank=True, default=dict),),
2018-11-11 12:41:48 +00:00
],
options={"permissions": (("reset_user_password", "Reset Password"),),},
bases=(guardian.mixins.GuardianUserMixin, models.Model),
managers=[("objects", django.contrib.auth.models.UserManager()),],
2018-11-11 12:41:48 +00:00
),
2019-02-16 09:24:31 +00:00
migrations.CreateModel(
2019-12-31 11:51:16 +00:00
name="PropertyMapping",
2018-11-11 12:41:48 +00:00
fields=[
2019-12-31 11:51:16 +00:00
(
"pm_uuid",
2019-12-31 11:51:16 +00:00
models.UUIDField(
default=uuid.uuid4,
editable=False,
primary_key=True,
serialize=False,
),
),
("name", models.TextField()),
("expression", models.TextField()),
2018-11-22 12:12:07 +00:00
],
options={
2019-12-31 11:51:16 +00:00
"verbose_name": "Property Mapping",
"verbose_name_plural": "Property Mappings",
2018-11-22 12:12:07 +00:00
},
),
migrations.CreateModel(
name="Source",
fields=[
2019-12-31 11:51:16 +00:00
(
"policybindingmodel_ptr",
models.OneToOneField(
auto_created=True,
2019-12-31 11:51:16 +00:00
on_delete=django.db.models.deletion.CASCADE,
parent_link=True,
primary_key=True,
serialize=False,
to="passbook_policies.PolicyBindingModel",
2019-12-31 11:51:16 +00:00
),
),
("name", models.TextField(help_text="Source's display Name.")),
(
"slug",
models.SlugField(help_text="Internal source name, used in URLs."),
),
("enabled", models.BooleanField(default=True)),
2019-12-31 11:51:16 +00:00
(
"property_mappings",
models.ManyToManyField(
blank=True, default=None, to="passbook_core.PropertyMapping"
2019-12-31 11:51:16 +00:00
),
),
2018-11-11 12:41:48 +00:00
],
bases=("passbook_policies.policybindingmodel",),
2019-02-16 09:24:31 +00:00
),
migrations.CreateModel(
name="UserSourceConnection",
2019-02-16 09:24:31 +00:00
fields=[
2019-12-31 11:51:16 +00:00
(
"id",
models.AutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("created", models.DateTimeField(auto_now_add=True)),
("last_updated", models.DateTimeField(auto_now=True)),
2019-12-31 11:51:16 +00:00
(
"source",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
to="passbook_core.Source",
),
),
(
"user",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
to=settings.AUTH_USER_MODEL,
2019-12-31 11:51:16 +00:00
),
),
2019-10-07 15:33:48 +01:00
],
options={"unique_together": {("user", "source")},},
2019-10-07 15:33:48 +01:00
),
migrations.CreateModel(
name="Token",
2019-10-07 15:33:48 +01:00
fields=[
2019-12-31 11:51:16 +00:00
(
"token_uuid",
2019-12-31 11:51:16 +00:00
models.UUIDField(
default=uuid.uuid4,
editable=False,
primary_key=True,
serialize=False,
),
),
(
"expires",
models.DateTimeField(
2020-05-16 15:11:53 +01:00
default=passbook.core.models.default_token_duration
2019-12-31 11:51:16 +00:00
),
),
("expiring", models.BooleanField(default=True)),
("description", models.TextField(blank=True, default="")),
2019-12-31 11:51:16 +00:00
(
"user",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="+",
2019-12-31 11:51:16 +00:00
to=settings.AUTH_USER_MODEL,
),
),
2019-02-16 09:24:31 +00:00
],
options={"verbose_name": "Token", "verbose_name_plural": "Tokens",},
2018-11-11 12:41:48 +00:00
),
2018-11-22 12:12:07 +00:00
migrations.CreateModel(
name="Provider",
2018-11-22 12:12:07 +00:00
fields=[
2019-12-31 11:51:16 +00:00
(
"id",
models.AutoField(
auto_created=True,
2019-12-31 11:51:16 +00:00
primary_key=True,
serialize=False,
verbose_name="ID",
2019-12-31 11:51:16 +00:00
),
),
(
"property_mappings",
models.ManyToManyField(
blank=True, default=None, to="passbook_core.PropertyMapping"
2019-12-31 11:51:16 +00:00
),
),
2018-11-22 12:12:07 +00:00
],
),
2018-12-10 09:49:50 +00:00
migrations.CreateModel(
name="Group",
2018-12-10 09:49:50 +00:00
fields=[
2019-12-31 11:51:16 +00:00
(
"group_uuid",
models.UUIDField(
default=uuid.uuid4,
editable=False,
2019-12-31 11:51:16 +00:00
primary_key=True,
serialize=False,
),
),
("name", models.CharField(max_length=80, verbose_name="name")),
2020-08-15 20:04:22 +01:00
("attributes", models.JSONField(blank=True, default=dict),),
2019-12-31 11:51:16 +00:00
(
"parent",
models.ForeignKey(
2019-12-31 11:51:16 +00:00
blank=True,
null=True,
on_delete=django.db.models.deletion.SET_NULL,
related_name="children",
to="passbook_core.Group",
2019-12-31 11:51:16 +00:00
),
),
2018-12-10 09:49:50 +00:00
],
options={"unique_together": {("name", "parent")},},
2018-11-11 12:41:48 +00:00
),
migrations.CreateModel(
name="Application",
fields=[
(
"policybindingmodel_ptr",
models.OneToOneField(
auto_created=True,
on_delete=django.db.models.deletion.CASCADE,
parent_link=True,
primary_key=True,
serialize=False,
to="passbook_policies.PolicyBindingModel",
),
),
("name", models.TextField(help_text="Application's display Name.")),
(
"slug",
models.SlugField(
help_text="Internal application name, used in URLs."
),
),
("skip_authorization", models.BooleanField(default=False)),
("meta_launch_url", models.URLField(blank=True, default="")),
("meta_icon_url", models.TextField(blank=True, default="")),
("meta_description", models.TextField(blank=True, default="")),
("meta_publisher", models.TextField(blank=True, default="")),
(
"provider",
models.OneToOneField(
blank=True,
default=None,
null=True,
on_delete=django.db.models.deletion.SET_DEFAULT,
to="passbook_core.Provider",
2019-12-31 11:51:16 +00:00
),
),
2019-10-07 15:33:48 +01:00
],
bases=("passbook_policies.policybindingmodel",),
),
migrations.AddField(
model_name="user",
name="groups",
field=models.ManyToManyField(to="passbook_core.Group"),
),
migrations.AddField(
model_name="user",
name="sources",
field=models.ManyToManyField(
through="passbook_core.UserSourceConnection", to="passbook_core.Source"
),
2018-11-11 12:41:48 +00:00
),
migrations.AddField(
model_name="user",
name="user_permissions",
field=models.ManyToManyField(
blank=True,
help_text="Specific permissions for this user.",
related_name="user_set",
related_query_name="user",
to="auth.Permission",
verbose_name="user permissions",
),
),
2018-11-11 12:41:48 +00:00
]