aboutsummaryrefslogtreecommitdiff
path: root/migrations/auth/20221110_07_7WGa1-create-role-privileges-table.py
blob: 0d0eeb94509b2199031857326ec66cee40e5e85a (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 'role_privileges' table
"""

from yoyo import step

__depends__ = {'20221110_06_Pq2kT-create-generic-roles-table'}

steps = [
    step(
        """
        CREATE TABLE IF NOT EXISTS role_privileges(
            role_id TEXT NOT NULL,
            privilege_id TEXT NOT NULL,
            PRIMARY KEY(role_id, privilege_id),
            FOREIGN KEY(role_id) REFERENCES roles(role_id)
              ON UPDATE CASCADE ON DELETE RESTRICT,
            FOREIGN KEY(privilege_id) REFERENCES privileges(privilege_id)
              ON UPDATE CASCADE ON DELETE RESTRICT
        ) WITHOUT ROWID
        """,
        "DROP TABLE IF EXISTS role_privileges"),
    step(
        """
        CREATE INDEX IF NOT EXISTS idx_tbl_role_privileges_cols_role_id
        ON role_privileges(role_id)
        """,
        "DROP INDEX IF EXISTS idx_tbl_role_privileges_cols_role_id")
]