forked from sekiskylink/dispatcher2
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdispatcher2.sql
88 lines (75 loc) · 3.16 KB
/
dispatcher2.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
CREATE TABLE servers(
id serial PRIMARY KEY NOT NULL,
name text NOT NULL,
username text NOT NULL DEFAULT '',
password text NOT NULL DEFAULT '',
ipaddress text NOT NULL DEFAULT '',
url text NOT NULL DEFAULT '',
auth_method text NOT NULL DEFAULT '',
cdate timestamptz DEFAULT current_timestamp
);
CREATE TABLE requests(
id bigserial PRIMARY KEY NOT NULL,
serverid integer REFERENCES servers(id),
request_body TEXT NOT NULL DEFAULT '',
status varchar(32) NOT NULL DEFAULT 'ready' CHECK( status IN('ready', 'inprogress', 'failed', 'error', 'expired', 'completed')),
statuscode text DEFAULT '',
retries integer NOT NULL DEFAULT 0,
errmsg text DEFAULT '',
submissionid integer NOT NULL DEFAULT 0, -- helpful when check for already sent submissions
week text DEFAULT'',
year int, -- year of submission
ldate timestamptz DEFAULT current_timestamp,
cdate timestamptz DEFAULT current_timestamp
);
CREATE INDEX requests_idx1 ON requests(submissionid);
CREATE INDEX requests_idx2 ON requests(status);
CREATE INDEX requests_idx3 ON requests(statuscode);
INSERT INTO servers (name, username, password, ipaddress, url, auth_method)
VALUES
('localhost', 'tester', 'foobar', '127.0.0.1', 'http://localhost:8080/test', 'Basic'),
('dhis2', 'tester', 'foobar', '127.0.0.1', 'http://hmis2.health.go.ug/api/dataValueSets', 'Basic');
-- Add some tables for the web interface
CREATE EXTENSION IF NOT EXISTS pgcrypto;
-- for web.py sessions
CREATE TABLE sessions (
session_id CHAR(128) UNIQUE NOT NULL,
atime TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
data TEXT
);
CREATE TABLE user_roles (
id BIGSERIAL NOT NULL PRIMARY KEY,
cdate TIMESTAMPTZ NOT NULL DEFAULT CURRENT_TIMESTAMP,
user_role TEXT NOT NULL UNIQUE,
descr text DEFAULT ''
);
CREATE TABLE user_role_permissions (
id bigserial NOT NULL PRIMARY KEY,
user_role BIGINT NOT NULL REFERENCES user_roles ON DELETE CASCADE ON UPDATE CASCADE,
Sys_module TEXT NOT NULL, -- the name of the module - defined above this level
sys_perms VARCHAR(16) NOT NULL,
unique(sys_module,user_role)
);
CREATE TABLE users (
id bigserial NOT NULL PRIMARY KEY,
cdate timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
firstname TEXT NOT NULL,
lastname TEXT NOT NULL,
username TEXT NOT NULL UNIQUE,
password TEXT NOT NULL, -- blowfish hash of password
email TEXT,
user_role BIGINT NOT NULL REFERENCES user_roles ON DELETE RESTRICT ON UPDATE CASCADE,
transaction_limit TEXT DEFAULT '0/'||to_char(NOW(),'yyyymmdd'),
is_active BOOLEAN NOT NULL DEFAULT 't',
is_system_user BOOLEAN NOT NULL DEFAULT 'f'
);
-- Data Follows
INSERT INTO user_roles(user_role, descr)
VALUES('Administrator','For the Administrators');
INSERT INTO user_role_permissions(user_role, sys_module,sys_perms)
VALUES
((SELECT id FROM user_roles WHERE user_role ='Administrator'),'Users','rmad');
INSERT INTO users(firstname,lastname,username,password,email,user_role,is_system_user)
VALUES
('Samuel','Sekiwere','admin',crypt('admin',gen_salt('bf')),'[email protected]',
(SELECT id FROM user_roles WHERE user_role ='Administrator'),'t');