You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
92 lines
5.0 KiB
Python
92 lines
5.0 KiB
Python
1 year ago
|
# Generated by Django 4.2.5 on 2023-09-21 17:15
|
||
|
|
||
|
from django.conf import settings
|
||
|
import django.contrib.auth.models
|
||
|
import django.contrib.auth.validators
|
||
|
from django.db import migrations, models
|
||
|
import django.db.models.deletion
|
||
|
import django.utils.timezone
|
||
|
|
||
|
|
||
|
class Migration(migrations.Migration):
|
||
|
|
||
|
initial = True
|
||
|
|
||
|
dependencies = [
|
||
|
('auth', '0012_alter_user_first_name_max_length'),
|
||
|
]
|
||
|
|
||
|
operations = [
|
||
|
migrations.CreateModel(
|
||
|
name='User',
|
||
|
fields=[
|
||
|
('id', models.BigAutoField(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=150, 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')),
|
||
|
('public_key', models.TextField()),
|
||
|
('private_key', models.TextField()),
|
||
|
('groups', models.ManyToManyField(blank=True, help_text='The groups this user belongs to. A user will get all permissions granted to each of their groups.', related_name='user_set', related_query_name='user', to='auth.group', verbose_name='groups')),
|
||
|
('user_permissions', 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')),
|
||
|
],
|
||
|
options={
|
||
|
'permissions': [('can_create_users', 'Can create new users')],
|
||
|
},
|
||
|
managers=[
|
||
|
('objects', django.contrib.auth.models.UserManager()),
|
||
|
],
|
||
|
),
|
||
|
migrations.CreateModel(
|
||
|
name='Attribute',
|
||
|
fields=[
|
||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||
|
('value', models.IntegerField()),
|
||
|
],
|
||
|
),
|
||
|
migrations.CreateModel(
|
||
|
name='AttributeType',
|
||
|
fields=[
|
||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||
|
('is_secret', models.BooleanField(default=False)),
|
||
|
('datatype', models.CharField(max_length=15)),
|
||
|
('significant_digits', models.PositiveIntegerField(blank=True, null=True)),
|
||
|
('name', models.CharField(max_length=40)),
|
||
|
],
|
||
|
),
|
||
|
migrations.CreateModel(
|
||
|
name='Rule',
|
||
|
fields=[
|
||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||
|
('rule_type', models.CharField(choices=[('and', 'AND'), ('or', 'OR')], max_length=3)),
|
||
|
('attributes', models.ManyToManyField(to='abac.attribute')),
|
||
|
],
|
||
|
),
|
||
|
migrations.CreateModel(
|
||
|
name='File',
|
||
|
fields=[
|
||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||
|
('name', models.CharField(max_length=255)),
|
||
|
('file', models.FileField(upload_to='uploads/')),
|
||
|
('owner', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
|
||
|
('rules', models.ManyToManyField(to='abac.rule')),
|
||
|
],
|
||
|
),
|
||
|
migrations.AddField(
|
||
|
model_name='attribute',
|
||
|
name='attribute_type',
|
||
|
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='abac.attributetype'),
|
||
|
),
|
||
|
migrations.AddField(
|
||
|
model_name='attribute',
|
||
|
name='user',
|
||
|
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL),
|
||
|
),
|
||
|
]
|