aboutsummaryrefslogtreecommitdiff
path: root/migrations/auth/20221206_01_BbeF9-create-group-user-roles-on-resources-table.py
blob: 9aa366722252806abdc57435bc08eaa46257ade6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
"""
Create 'group_user_roles_on_resources' table
"""

from yoyo import step

__depends__ = {'20221117_02_fmuZh-create-group-users-table'}

steps = [
    step(
        """
        CREATE TABLE group_user_roles_on_resources (
            group_id TEXT NOT NULL,
            user_id TEXT NOT NULL,
            role_id TEXT NOT NULL,
            resource_id TEXT NOT NULL,
            PRIMARY KEY (group_id, user_id, role_id, resource_id),
            FOREIGN KEY (user_id)
              REFERENCES users(user_id)
              ON UPDATE CASCADE ON DELETE RESTRICT,
            FOREIGN KEY (group_id, role_id)
              REFERENCES group_roles(group_id, role_id)
              ON UPDATE CASCADE ON DELETE RESTRICT,
            FOREIGN KEY (group_id, resource_id)
              REFERENCES resources(group_id, resource_id)
              ON UPDATE CASCADE ON DELETE RESTRICT
        ) WITHOUT ROWID
        """,
        "DROP TABLE IF EXISTS group_user_roles_on_resources"),
    step(
        """
        CREATE INDEX IF NOT EXISTS
            idx_tbl_group_user_roles_on_resources_group_user_resource
        ON group_user_roles_on_resources(group_id, user_id, resource_id)
        """,
        """
        DROP INDEX IF EXISTS
            idx_tbl_group_user_roles_on_resources_group_user_resource""")
]