Skip to content
Snippets Groups Projects
core.tsql 4.17 KiB
Newer Older
/* Users */
CREATE TABLE @PREFIX@users (
	ID			@SERIAL_TYPE@,

	Username		VARCHAR(255) NOT NULL,

Nigel Kukard's avatar
Nigel Kukard committed
	Disabled		SMALLINT NOT NULL DEFAULT '0',

	UNIQUE (Username)
) @CREATE_TABLE_SUFFIX@;
CREATE INDEX @PREFIX@users_idx1 ON @PREFIX@users (Username);


Nigel Kukard's avatar
Nigel Kukard committed
/* User attributes */
CREATE TABLE @PREFIX@user_attributes (
	ID			@SERIAL_TYPE@,

	UserID			@SERIAL_REF_TYPE@ NOT NULL,

	Name			VARCHAR(255) NOT NULL,
	Operator		VARCHAR(4) NOT NULL,
	Value			VARCHAR(255),

Nigel Kukard's avatar
Nigel Kukard committed
	Disabled		SMALLINT NOT NULL DEFAULT '0',
	FOREIGN KEY (UserID) REFERENCES @PREFIX@users(ID)
) @CREATE_TABLE_SUFFIX@;


/* Groups */
CREATE TABLE @PREFIX@groups (
	ID			@SERIAL_TYPE@,

	Name			VARCHAR(255) NOT NULL,

	Priority		SMALLINT NOT NULL,

	Disabled		SMALLINT NOT NULL DEFAULT '0',

	Comment			VARCHAR(1024)

)  @CREATE_TABLE_SUFFIX@;
Nigel Kukard's avatar
Nigel Kukard committed
CREATE INDEX @PREFIX@groups_idx1 ON @PREFIX@groups (Name);
Nigel Kukard's avatar
Nigel Kukard committed
/* Group attributes */
CREATE TABLE @PREFIX@group_attributes (
	ID			@SERIAL_TYPE@,

	GroupID			@SERIAL_REF_TYPE@ NOT NULL,

	Name			VARCHAR(255) NOT NULL,
	Operator		VARCHAR(4) NOT NULL,
	Value			VARCHAR(255),

Nigel Kukard's avatar
Nigel Kukard committed
	Disabled		SMALLINT NOT NULL DEFAULT '0',
	FOREIGN KEY (GroupID) REFERENCES @PREFIX@groups(ID)
) @CREATE_TABLE_SUFFIX@;


/* User to group mapping */
CREATE TABLE @PREFIX@users_to_groups (
	ID			@SERIAL_TYPE@,

	UserID			@SERIAL_REF_TYPE@ NOT NULL,
	GroupID			@SERIAL_REF_TYPE@ NOT NULL,

	Disabled		SMALLINT NOT NULL DEFAULT '0',
	Comment			VARCHAR(1024),

	UNIQUE (UserID,GroupID),
	FOREIGN KEY (UserID) REFERENCES @PREFIX@users(ID),
	FOREIGN KEY (GroupID) REFERENCES @PREFIX@groups(ID)
)  @CREATE_TABLE_SUFFIX@;
CREATE INDEX @PREFIX@users_to_groups_idx1 ON @PREFIX@users_to_groups (UserID,GroupID);


Robert Anderson's avatar
Robert Anderson committed
/* Topups */
CREATE TABLE @PREFIX@topups (
	ID			@SERIAL_TYPE@,

	UserID			@SERIAL_REF_TYPE@ NOT NULL,

				/* 1 = traffic topup, 2 = uptime topup */
	Type			@INT_UNSIGNED@,

Robert Anderson's avatar
Robert Anderson committed
	ValidFrom		DATETIME,
	ValidTo			DATETIME,

	Value			@INT_UNSIGNED@,

	Depleted		SMALLINT NOT NULL DEFAULT '0',

Robert Anderson's avatar
Robert Anderson committed
	FOREIGN KEY (UserID) REFERENCES @PREFIX@users(ID)
) @CREATE_TABLE_SUFFIX@;


/* Realms */
CREATE TABLE @PREFIX@realms (
	ID			@SERIAL_TYPE@,

	Name			VARCHAR(255) NOT NULL,

Robert Anderson's avatar
Robert Anderson committed
	Disabled		SMALLINT NOT NULL DEFAULT '0'

)  @CREATE_TABLE_SUFFIX@;
CREATE INDEX @PREFIX@realms_idx1 ON @PREFIX@realms (Name);



/* Realm attributes */
CREATE TABLE @PREFIX@realm_attributes (
	ID			@SERIAL_TYPE@,

	RealmID			@SERIAL_REF_TYPE@ NOT NULL,

	Name			VARCHAR(255) NOT NULL,
	Operator		VARCHAR(4) NOT NULL,
	Value			VARCHAR(255),

	Disabled		SMALLINT NOT NULL DEFAULT '0',

	FOREIGN KEY (RealmID) REFERENCES @PREFIX@realms(ID)
) @CREATE_TABLE_SUFFIX@;



/* Topups Summary */
CREATE TABLE @PREFIX@topups_summary (
	ID			@SERIAL_TYPE@,

	TopupID			@SERIAL_REF_TYPE@ NOT NULL,

	PeriodKey		DATETIME, 

	Balance			@INT_UNSIGNED@,

	Depleted		SMALLINT NOT NULL DEFAULT '0',

	FOREIGN KEY (TopupID) REFERENCES @PREFIX@topups(ID)
) @CREATE_TABLE_SUFFIX@;


/* Accounting Summary */
CREATE TABLE @PREFIX@accounting_summary (
	ID			@SERIAL_TYPE@,

	Username		VARCHAR(255),

	PeriodKey		DATETIME,

	AcctSessionTime		@INT_UNSIGNED@,

	AcctInputOctets		@INT_UNSIGNED@,

	AcctInputGigawords	@INT_UNSIGNED@,

	AcctInputPackets	@INT_UNSIGNED@,

	AcctOutputOctets	@INT_UNSIGNED@,

	AcctOutputGigawords	@INT_UNSIGNED@
) @CREATE_TABLE_SUFFIX@;



/* Accounting */
CREATE TABLE @PREFIX@accounting (
	ID			@SERIAL_TYPE@,

	NASIdentifier		VARCHAR(255),
	AcctSessionTime		@INT_UNSIGNED@,
	AcctInputOctets		@INT_UNSIGNED@,
	AcctInputGigawords	@INT_UNSIGNED@,
	AcctInputPackets	@INT_UNSIGNED@,
	AcctOutputOctets	@INT_UNSIGNED@,
	AcctOutputGigawords	@INT_UNSIGNED@,
	AcctOutputPackets	@INT_UNSIGNED@,
	AcctTerminateCause	@INT_UNSIGNED@
) @CREATE_TABLE_SUFFIX@;
CREATE INDEX @PREFIX@accounting_idx1 ON @PREFIX@accounting (Username);