diff options
Diffstat (limited to 'examples')
| -rw-r--r-- | examples/schema.sql | 203 | 
1 files changed, 0 insertions, 203 deletions
| diff --git a/examples/schema.sql b/examples/schema.sql deleted file mode 100644 index e6826cf..0000000 --- a/examples/schema.sql +++ /dev/null @@ -1,203 +0,0 @@ -/* - * SCROTT IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF - * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. - * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR - * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, - * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR - * OTHER DEALINGS IN THE SOFTWARE. - * - * For more information, please refer to UNLICENSE - */ - -/* - * Execute this SQL script file to create or recreate a relational - * database schema for use with Scrott.  This file targets MySQL (MariaDB), - * however may be applicable to other DBMSs as well.  If necessary, - * alternative versions of this file may be tracked to support those - * systems. - * - * Scrott's data model emulates object-oriented structures in the database - * schema and features a generic "object" table containing fields pertinent - * all object types.  Additional tables extend this for each class of - * objects, referencing a row in the object table by GUID.  All objects are - * uniquely identifiable by a GUID which is, in our case, an 8-digit - * hexadecimal string. - */ - -CREATE DATABASE IF NOT EXISTS db_scrott; -USE db_scrott; - -/* - * This table describes a dictionary used for recording system settings - * and configuration.  These are application-wide and only writable by - * administrators.  This table will only hold values which have been - * changed and the app will use built-in defaults for settings *not* - * defined by this table. - */ -DROP TABLE IF EXISTS settings; -CREATE TABLE settings ( -    name        varchar(64)         NOT NULL, -    value       varchar(64)     DEFAULT NULL, - -    PRIMARY KEY (name) -); - -/* - * This table tracks membership.  Users may be members of groups, pads, - * and issues as part of the permissions system.  This table is a many- - * to-many relationship between users and other objects that is - * representative of existing memberships. - */ -DROP TABLE IF EXISTS members; -CREATE TABLE members ( -    guid        varchar(8)          NOT NULL, -    member      varchar(8)          NOT NULL, - -    PRIMARY KEY (guid, member) -); - -/* - * This table records whether messages have been seen by any user.  This - * table is a many-to-many relationship between users and messages. - */ -DROP TABLE IF EXISTS views; -CREATE TABLE views ( -    guid        varchar(8)          NOT NULL, -    viewer      varchar(8)          NOT NULL, - -    PRIMARY KEY (guid, viewer) -); - -/* - * Base table for Scrott objects - * - * Explaination of permissions... - * Every object has an owner, zero or more additional members, and then there is the general - * public. - *                                              OWNER       MEMBERS         PUBLIC - * Permissions are:                         ------------------------------------------ - *      Access object                           GRANTED     GRANTED         config - *      Modify object                           GRANTED     config          DENIED - *      Modify members                          GRANTED     config          DENIED - *      Modify permissions                      GRANTED     DENIED          DENIED - *      Access sub-objects                      GRANTED     config          config - *      Create sub-objects                      GRANTED     config          config - *      Modify sub-objects                      GRANTED     config          DENIED - *      Modify sub-objects' members             GRANTED     config          DENIED - *      Modify sub-objects' permissions         GRANTED     DENIED          DENIED - * - * Permissions can be overridden in sub-objects, but will cascade otherwise. - */ -DROP TABLE IF EXISTS objects; -CREATE TABLE objects ( -    guid        varchar(8)          NOT NULL, -    owner       varchar(8)      DEFAULT NULL, -    parent      varchar(8)      DEFAULT NULL, -    name        varchar(64)         NOT NULL, -    created     datetime            NOT NULL, -    updated     datetime            NOT NULL, - -    membModify  int(1)              NOT NULL    DEFAULT 0,      /* members can modify object */ -    membMemb    int(1)              NOT NULL    DEFAULT 0,      /* members can modify members */ -    membAccs    int(1)              NOT NULL    DEFAULT 1,      /* members can access sub-objects */ -    membCres    int(1)              NOT NULL    DEFAULT 1,      /* members can create sub-objects */ -    membModifys int(1)              NOT NULL    DEFAULT 1,      /* members can modify sub-objects */ -    membMembs   int(1)              NOT NULL    DEFAULT 1,      /* members can modify sub-obj members */ -    pubAcc      int(1)              NOT NULL    DEFAULT 0,      /* public can access object */ -    pubAccs     int(1)              NOT NULL    DEFAULT 0,      /* public can access sub-objects */ -    pubCres     int(1)              NOT NULL    DEFAULT 0,      /* public can create sub-objects */ - -    objtype     enum ( -                    'user', -                    'group', -                    'pad', -                    'stage', -                    'issue', -                    'message', -                    'log' -                )                   NOT NULL, - -    PRIMARY KEY (guid) -); - -/* - * Users -- extends objects - */ -DROP TABLE IF EXISTS users; -CREATE TABLE users ( -    guid        varchar(8)          NOT NULL, -    auth        varchar(64)         NOT NULL,                   /* user's salted and hashed passwd -- SHA256 */ -    salt        varchar(64)         NOT NULL,                   /* random SHA256 output, used as salt for auth */ -    alias       varchar(64)     DEFAULT NULL, -    email       varchar(64)     DEFAULT NULL, -    emailVer    varchar(8)          NOT NULL, -    admin       int(1)              NOT NULL    DEFAULT 0, -    reg         int(1)              NOT NULL    DEFAULT 0,      /* if false, user doesn't have valid credentials */ -    emailConf   int(1)              NOT NULL    DEFAULT 0, - -    PRIMARY KEY (guid) -); - -/* - * Groups -- extends objects - */ -DROP TABLE IF EXISTS groups; -CREATE TABLE groups ( -    guid        varchar(8)          NOT NULL, - -    PRIMARY KEY (guid) -); - -/* - * Pads -- extends objects - */ -DROP TABLE IF EXISTS pads; -CREATE TABLE pads ( -    guid        varchar(8)          NOT NULL, -    stage       varchar(8)      DEFAULT NULL, -    issueNumb   int(32)             NOT NULL    DEFAULT 0, - -    PRIMARY KEY (guid) -); - -/* - * Stages -- extends objects - */ -DROP TABLE IF EXISTS stages; -CREATE TABLE stages ( -    guid        varchar(8)          NOT NULL, -    stage       varchar(8)      DEFAULT NULL, - -    PRIMARY KEY (guid) -); - -/* - * Issues -- extends objects - */ -DROP TABLE IF EXISTS issues; -CREATE TABLE issues ( -    guid        varchar(8)          NOT NULL, -    numb        int(32)             NOT NULL, -    assignee    varchar(8)      DEFAULT NULL, -    seen        int(1)              NOT NULL    DEFAULT 0,      /* has the assignee seen this yet? */ -    description text            DEFAULT NULL, -    due         datetime        DEFAULT NULL, -    tags        varchar(64)     DEFAULT NULL, - -    PRIMARY KEY (guid) -); - -/* - * Messages / logs -- extends objects - */ -DROP TABLE IF EXISTS mesgs; -CREATE TABLE mesgs ( -    guid        varchar(8)          NOT NULL, -    author      varchar(8)          NOT NULL, -    mesg        text            DEFAULT NULL, -    attachName  varchar(64)     DEFAULT NULL, -    attachMime  varchar(64)     DEFAULT NULL, - -    PRIMARY KEY (guid) -); | 
