begin; -- Central DB structure -- This is the central database stuff which is used across all datasets -- in the ledger-smb.conf it is called 'ledgersmb' by default, but obviously -- can be named anything. -- USERS stuff -- CREATE TABLE users (id serial UNIQUE, username varchar(30) primary key); COMMENT ON TABLE users IS $$username is the actual primary key here because we do not want duplicate users$$; CREATE TABLE users_conf(id integer primary key references users(id) deferrable initially deferred, acs text, address text, businessnumber text, company text, countrycode text, currency text, dateformat text, dbdriver text default 'Pg', dbhost text default 'localhost', dbname text, dboptions text, dbpasswd text, dbport text, dbuser text, email text, fax text, menuwidth text, name text, numberformat text, password varchar(32) check(length(password) = 32), crypted_password text, print text, printer text, role text, sid text, signature text, stylesheet text, tel text, templates text, timeout numeric, vclimit numeric); COMMENT ON TABLE users_conf IS 'This is a completely dumb table that is a place holder to get usersconf into the database. Next major release will have a much more sane implementation'; COMMENT ON COLUMN users_conf.id IS 'Yes primary key with a FOREIGN KEY to users(id) is correct'; COMMENT ON COLUMN users_conf.password IS 'This means we have to get rid of the current password stuff and move to presumably md5()'; -- Per conversation with ChrisM, if the admin user has a null password a couple of things happen. -- 1. It is implicit that this is an initial install -- 2. If the admin password does not match the ledger-smb.conf admin password, we throw a hijack alert -- The two below statements must be run from a single session INSERT INTO users(username) VALUES ('admin'); INSERT INTO users_conf(id,password) VALUES (currval('users_id_seq'),NULL); CREATE OR REPLACE FUNCTION create_user(text) RETURNS bigint AS $$ INSERT INTO users(username) VALUES ($1); SELECT currval('users_id_seq'); $$ LANGUAGE 'SQL'; COMMENT ON FUNCTION create_user(text) IS $$ Function to create user. Returns users.id if successful, else it is an error. $$; CREATE OR REPLACE FUNCTION update_user(int4,text) RETURNS int4 AS $$ UPDATE users SET username = $2 WHERE id = $1; SELECT 1; $$ LANGUAGE 'SQL'; COMMENT ON FUNCTION update_user(int4,text) IS $$ Takes int4 which is users.id and text which is username. Will update username based on id. Username is unique $$; -- Session tracking table CREATE TABLE session( session_id serial PRIMARY KEY, sl_login VARCHAR(50), token VARCHAR(32) CHECK(length(token) = 32), last_used TIMESTAMP default now(), users_id INTEGER -- NOT NULL references users(id) ); commit;