aboutsummaryrefslogtreecommitdiff
path: root/migrations/auth/20221114_03_PtWjc-create-group-roles-table.py
blob: a7e7b45e84efdcec50e5284500348f1dc4f7181d (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
"""
Create 'group_roles' table
"""

from yoyo import step

__depends__ = {'20221114_02_DKKjn-drop-generic-role-tables'}

steps = [
    step(
        """
        CREATE TABLE IF NOT EXISTS group_roles(
            group_id TEXT NOT NULL,
            role_id TEXT NOT NULL,
            PRIMARY KEY(group_id, role_id),
            FOREIGN KEY(group_id) REFERENCES groups(group_id)
              ON UPDATE CASCADE ON DELETE RESTRICT,
            FOREIGN KEY(role_id) REFERENCES roles(role_id)
              ON UPDATE CASCADE ON DELETE RESTRICT
        ) WITHOUT ROWID
        """,
        "DROP TABLE IF EXISTS group_roles"),
    step(
        """
        CREATE INDEX IF NOT EXISTS idx_tbl_group_roles_cols_group_id
        ON group_roles(group_id)
        """,
        "DROP INDEX IF EXISTS idx_tbl_group_roles_cols_group_id")
]