Emmanuel BENOîT
e50775ec76
* The main loader script has been updated to generate the list of files it needs to load automatically. As a consequence, files that contained manually-maintained lists of scripts have been removed, and definition directories have been renamed accordingly. * PostgreSQL extension loading and configuration has been moved to a separate script to be loaded automatically in the main transaction. * Data and function definition scripts that had the -data or -functions suffix have been renamed (the suffix is unnecessary). * Unit tests have been reorganised to follow the definition's structure. * Documentation has been improved
92 lines
1.9 KiB
SQL
92 lines
1.9 KiB
SQL
-- LegacyWorlds Beta 6
|
|
-- PostgreSQL database scripts
|
|
--
|
|
-- User sessions tables
|
|
--
|
|
-- Copyright(C) 2004-2010, DeepClone Development
|
|
-- --------------------------------------------------------
|
|
|
|
|
|
--
|
|
-- Session client type definitions
|
|
--
|
|
|
|
CREATE TABLE defs.session_clients(
|
|
id SERIAL PRIMARY KEY ,
|
|
name VARCHAR( 16 ) NOT NULL UNIQUE ,
|
|
exclusive BOOLEAN NOT NULL
|
|
);
|
|
|
|
--
|
|
-- Default session client types
|
|
--
|
|
|
|
INSERT INTO defs.session_clients ( name , exclusive )
|
|
VALUES( 'web' , TRUE );
|
|
INSERT INTO defs.session_clients ( name , exclusive )
|
|
VALUES( 'vac_end' , FALSE );
|
|
|
|
|
|
|
|
--
|
|
-- Types of session termination
|
|
--
|
|
|
|
CREATE TYPE session_termination_type
|
|
AS ENUM( 'MANUAL' , 'GONE' , 'EXPIRED' , 'EXCLUSIVE' , 'SERVER' );
|
|
|
|
|
|
|
|
--
|
|
-- User sessions start
|
|
--
|
|
|
|
CREATE TABLE users.session_starts(
|
|
id BIGSERIAL PRIMARY KEY ,
|
|
credentials_id INT NOT NULL ,
|
|
client_id INT NOT NULL ,
|
|
session VARCHAR( 64 ) NOT NULL ,
|
|
started TIMESTAMP WITHOUT TIME ZONE
|
|
NOT NULL
|
|
DEFAULT now( ) ,
|
|
from_address VARCHAR( 64 ) NOT NULL
|
|
);
|
|
|
|
CREATE INDEX idx_sessstart_credentials
|
|
ON users.session_starts ( credentials_id );
|
|
|
|
CREATE INDEX idx_sessstart_client
|
|
ON users.session_starts ( client_id );
|
|
|
|
CREATE INDEX idx_sessstart_started
|
|
ON users.session_starts ( started );
|
|
|
|
ALTER TABLE users.session_starts
|
|
ADD CONSTRAINT fk_sessstart_credentials
|
|
FOREIGN KEY ( credentials_id ) REFERENCES users.credentials
|
|
ON DELETE CASCADE ON UPDATE CASCADE ,
|
|
ADD CONSTRAINT fk_sessstart_client
|
|
FOREIGN KEY ( client_id ) REFERENCES defs.session_clients;
|
|
|
|
|
|
|
|
--
|
|
-- User sessions end
|
|
--
|
|
|
|
CREATE TABLE users.session_ends(
|
|
id BIGINT NOT NULL PRIMARY KEY ,
|
|
ended TIMESTAMP WITHOUT TIME ZONE
|
|
NOT NULL
|
|
DEFAULT now( ) ,
|
|
end_type session_termination_type NOT NULL
|
|
);
|
|
|
|
CREATE INDEX idx_sessend_ended
|
|
ON users.session_ends ( ended );
|
|
|
|
ALTER TABLE users.session_ends
|
|
ADD CONSTRAINT fk_sessend_id
|
|
FOREIGN KEY ( id ) REFERENCES users.session_starts
|
|
ON DELETE CASCADE;
|
|
|