aboutsummaryrefslogtreecommitdiff
path: root/migrations/auth/20221110_07_7WGa1-create-role-privileges-table.py
diff options
context:
space:
mode:
Diffstat (limited to 'migrations/auth/20221110_07_7WGa1-create-role-privileges-table.py')
-rw-r--r--migrations/auth/20221110_07_7WGa1-create-role-privileges-table.py29
1 files changed, 29 insertions, 0 deletions
diff --git a/migrations/auth/20221110_07_7WGa1-create-role-privileges-table.py b/migrations/auth/20221110_07_7WGa1-create-role-privileges-table.py
new file mode 100644
index 0000000..0d0eeb9
--- /dev/null
+++ b/migrations/auth/20221110_07_7WGa1-create-role-privileges-table.py
@@ -0,0 +1,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")
+]