2010-08-21 14:43:03 +10:00
|
|
|
CREATE TABLE roles
|
|
|
|
(
|
|
|
|
id serial,
|
|
|
|
"name" varchar(32) NOT NULL,
|
|
|
|
description text NOT NULL,
|
|
|
|
CONSTRAINT roles_id_pkey PRIMARY KEY (id),
|
|
|
|
CONSTRAINT roles_name_key UNIQUE (name)
|
|
|
|
);
|
|
|
|
|
|
|
|
CREATE TABLE roles_users
|
|
|
|
(
|
|
|
|
user_id integer,
|
|
|
|
role_id integer
|
|
|
|
);
|
|
|
|
|
|
|
|
CREATE TABLE users
|
|
|
|
(
|
|
|
|
id serial,
|
2012-11-09 23:18:50 +11:00
|
|
|
email varchar(254) NOT NULL,
|
2010-08-21 14:43:03 +10:00
|
|
|
username varchar(32) NOT NULL,
|
2011-05-13 16:00:25 +10:00
|
|
|
"password" varchar(64) NOT NULL,
|
2010-08-21 14:43:03 +10:00
|
|
|
logins integer NOT NULL DEFAULT 0,
|
|
|
|
last_login integer,
|
|
|
|
CONSTRAINT users_id_pkey PRIMARY KEY (id),
|
|
|
|
CONSTRAINT users_username_key UNIQUE (username),
|
|
|
|
CONSTRAINT users_email_key UNIQUE (email),
|
|
|
|
CONSTRAINT users_logins_check CHECK (logins >= 0)
|
|
|
|
);
|
|
|
|
|
|
|
|
CREATE TABLE user_tokens
|
|
|
|
(
|
|
|
|
id serial,
|
|
|
|
user_id integer NOT NULL,
|
|
|
|
user_agent varchar(40) NOT NULL,
|
|
|
|
token character varying(32) NOT NULL,
|
|
|
|
created integer NOT NULL,
|
|
|
|
expires integer NOT NULL,
|
|
|
|
CONSTRAINT user_tokens_id_pkey PRIMARY KEY (id),
|
|
|
|
CONSTRAINT user_tokens_token_key UNIQUE (token)
|
|
|
|
);
|
|
|
|
|
|
|
|
CREATE INDEX user_id_idx ON roles_users (user_id);
|
|
|
|
CREATE INDEX role_id_idx ON roles_users (role_id);
|
|
|
|
|
|
|
|
ALTER TABLE roles_users
|
|
|
|
ADD CONSTRAINT user_id_fkey FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE CASCADE,
|
|
|
|
ADD CONSTRAINT role_id_fkey FOREIGN KEY (role_id) REFERENCES roles(id) ON DELETE CASCADE;
|
|
|
|
|
|
|
|
ALTER TABLE user_tokens
|
|
|
|
ADD CONSTRAINT user_id_fkey FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE CASCADE;
|
|
|
|
|
|
|
|
INSERT INTO roles (name, description) VALUES ('login', 'Login privileges, granted after account confirmation');
|
2011-05-13 16:00:25 +10:00
|
|
|
INSERT INTO roles (name, description) VALUES ('admin', 'Administrative user, has access to everything.');
|