0
0
mirror of https://github.com/PostHog/posthog.git synced 2024-11-30 19:41:46 +01:00
posthog/ee/migrations/0014_roles_memberships_and_resource_access.py
Tom Owers 5513be7731
chore: upgraded Ruff linter (#18188)
* Upgraded Ruff linter

* Formatted whole codebase with new ruff rules

* Revert import removal

* Fixed mypi issues or added ignores

* Fixed schema formatting

* Fixed hogvm failing tests

* Remove duplicate key in list
2023-10-26 12:38:15 +02:00

202 lines
7.3 KiB
Python

# Generated by Django 3.2.16 on 2022-11-23 17:34
import django.db.models.deletion
from django.conf import settings
from django.db import migrations, models
import posthog.models.utils
class Migration(migrations.Migration):
dependencies = [
("posthog", "0280_fix_async_deletion_team"),
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
("ee", "0013_silence_deprecated_tags_warnings"),
]
operations = [
migrations.CreateModel(
name="Role",
fields=[
(
"id",
models.UUIDField(
default=posthog.models.utils.UUIDT,
editable=False,
primary_key=True,
serialize=False,
),
),
("name", models.CharField(max_length=200)),
(
"feature_flags_access_level",
models.PositiveSmallIntegerField(
choices=[(21, "Can only view"), (37, "Can always edit")],
default=37,
),
),
("created_at", models.DateTimeField(auto_now_add=True)),
(
"created_by",
models.ForeignKey(
null=True,
on_delete=django.db.models.deletion.SET_NULL,
related_name="roles",
related_query_name="role",
to=settings.AUTH_USER_MODEL,
),
),
(
"organization",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="roles",
related_query_name="role",
to="posthog.organization",
),
),
],
),
migrations.CreateModel(
name="RoleMembership",
fields=[
(
"id",
models.UUIDField(
default=posthog.models.utils.UUIDT,
editable=False,
primary_key=True,
serialize=False,
),
),
("joined_at", models.DateTimeField(auto_now_add=True)),
("updated_at", models.DateTimeField(auto_now=True)),
(
"role",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="roles",
related_query_name="role",
to="ee.role",
),
),
(
"user",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="role_memberships",
related_query_name="role_membership",
to=settings.AUTH_USER_MODEL,
),
),
],
),
migrations.CreateModel(
name="OrganizationResourceAccess",
fields=[
(
"id",
models.AutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
(
"resource",
models.CharField(
choices=[
("feature flags", "feature flags"),
("experiments", "experiments"),
("cohorts", "cohorts"),
("data management", "data management"),
("session recordings", "session recordings"),
("insights", "insights"),
("dashboards", "dashboards"),
],
max_length=32,
),
),
(
"access_level",
models.PositiveSmallIntegerField(
choices=[(21, "Can only view"), (37, "Can always edit")],
default=37,
),
),
("created_at", models.DateTimeField(auto_now_add=True)),
("updated_at", models.DateTimeField(auto_now=True)),
(
"created_by",
models.ForeignKey(
null=True,
on_delete=django.db.models.deletion.SET_NULL,
to=settings.AUTH_USER_MODEL,
),
),
(
"organization",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="resource_access",
to="posthog.organization",
),
),
],
),
migrations.CreateModel(
name="FeatureFlagRoleAccess",
fields=[
(
"id",
models.AutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("added_at", models.DateTimeField(auto_now_add=True)),
("updated_at", models.DateTimeField(auto_now=True)),
(
"feature_flag",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="access",
related_query_name="access",
to="posthog.featureflag",
),
),
(
"role",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="feature_flag_access",
related_query_name="feature_flag_access",
to="ee.role",
),
),
],
),
migrations.AddConstraint(
model_name="rolemembership",
constraint=models.UniqueConstraint(fields=("role", "user"), name="unique_user_and_role"),
),
migrations.AddConstraint(
model_name="role",
constraint=models.UniqueConstraint(fields=("organization", "name"), name="unique_role_name"),
),
migrations.AddConstraint(
model_name="organizationresourceaccess",
constraint=models.UniqueConstraint(
fields=("organization", "resource"),
name="unique resource per organization",
),
),
migrations.AddConstraint(
model_name="featureflagroleaccess",
constraint=models.UniqueConstraint(fields=("role", "feature_flag"), name="unique_feature_flag_and_role"),
),
]