/* 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', 'pad', 'stage' ) 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 */ /* Pad objects - special attributes */ DROP TABLE IF EXISTS `pad`; CREATE TABLE `pad` ( `guid` varchar(10) NOT NULL, `stage` varchar(10) DEFAULT NULL, PRIMARY KEY (`guid`) ); /* Stage objects - special attributes */ DROP TABLE IF EXISTS `stage`; CREATE TABLE `stage` ( `guid` varchar(10) NOT NULL, `stage` varchar(10) DEFAULT NULL, PRIMARY KEY (`guid`) );