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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
|
/* SCROTT - Core System Data Structures
* ------------------------------------
* SQL Database Schema for backend
*/
CREATE DATABASE IF NOT EXISTS `db_scrott`;
USE `db_scrott`;
/* Description of SCROTT object permissions system
* -----------------------------------------------
* Every object has an owner, zero or more additional members, and then there is the general
* public.
*
* OWNER = user OR group
* MEMBER = user
* OWNER MEMBERS OTHERS
* Permissions are: ------------------------------------------------
* 1. Access object GRANTED GRANTED MB #6
* 2. Modify object GRANTED MB #0 DENIED
* 3. Modify members GRANTED MB #1 DENIED
* 4. Modify permissions GRANTED DENIED DENIED
* 5. Access sub-objects GRANTED MB #2 MB #7
* 6. Create sub-objects GRANTED MB #3 MB #8
* 7. Modify sub-objects GRANTED MB #4 DENIED
* 8. Modify sub-objects' members GRANTED MB #5 DENIED
* 9. Modify sub-objects' permissions GRANTED DENIED DENIED
*
* 012345678
* EG: 001111000 = 120 --implies--> that members may access,create,and
* fully modify sub-objects. All other
* options are DENIED. This mask value
* of 120 is a recommended starting point.
*
* Permissions can be overridden down-stream, but permissions will cascade otherwise.
*/
/* Common object structure attributes */
DROP TABLE IF EXISTS `object`;
CREATE TABLE `object` (
`guid` varchar(10) NOT NULL,
`perms` int(10) unsigned NOT NULL DEFAULT 0,
`owner` varchar(10) NOT NULL,
`parent` varchar(10) DEFAULT NULL,
`name` varchar(50) NOT NULL,
`type` enum(
'user',
'group'
) NOT NULL,
PRIMARY KEY (`guid`)
);
/* Scheme for associating objects with members */
DROP TABLE IF EXISTS `obj_member`;
CREATE TABLE `obj_member` (
`guid` varchar(10) NOT NULL,
`member` varchar(10) NOT NULL,
PRIMARY KEY (`guid`,`member`)
);
/* User objects - special attributes */
DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
`guid` varchar(10) NOT NULL,
`key` varchar(64) NOT NULL,
`salt` varchar(64) NOT NULL,
`alias` varchar(50) DEFAULT NULL,
PRIMARY KEY (`guid`)
);
/* object type 'group' has no unique attributes */
/* TODO -- WIP FROM HERE */
DROP TABLE IF EXISTS `pad`;
CREATE TABLE `pad` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`guid` varchar(10) NOT NULL,
`owner` varchar(10) NOT NULL,
`perms` int(10) unsigned NOT NULL,
`name` varchar(50) NOT NULL,
PRIMARY KEY (`id`)
);
DROP TABLE IF EXISTS `stage`;
CREATE TABLE `stage` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`guid` varchar(10) NOT NULL,
`owner` varchar(10) NOT NULL,
`perms` int(10) unsigned NOT NULL,
`name` varchar(50) NOT NULL,
`parent` varchar(10) NOT NULL,
/* TODO -- wip */
PRIMARY KEY (`id`)
);
|