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""")
]
|