This repository has been archived on 2025-01-04. You can view files and clone it, but cannot push or open issues or pull requests.
lwb6/legacyworlds-server-data/db-structure/parts/030-data/035-session.sql
Emmanuel BENOîT e50775ec76 Database definition & tests organisation
* 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
2012-01-06 11:19:19 +01:00

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;