summaryrefslogtreecommitdiff
path: root/demos/time-tracker/protected/App_Data/MySQL4/time-tracker-mysql.sql
blob: bb120fc416fd690a6a1cb8fb25469b45efe7eb8d (plain)
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
DROP TABLE IF EXISTS user_roles;
CREATE TABLE user_roles (
  UserID varchar(50) NOT NULL,
  RoleType varchar(50) NOT NULL,
  PRIMARY KEY  (UserID,RoleType),
  KEY RoleType (RoleType)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

DROP TABLE IF EXISTS role_types;
CREATE TABLE role_types (
  RoleType varchar(50) NOT NULL,
  Description varchar(255) NOT NULL,
  PRIMARY KEY  (RoleType)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

DROP TABLE IF EXISTS project_members;
CREATE TABLE project_members (
  UserID varchar(50) NOT NULL,
  ProjectID int(11) NOT NULL,
  PRIMARY KEY  (UserID,ProjectID),
  KEY ProjectID (ProjectID)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

DROP TABLE IF EXISTS time_entry;
CREATE TABLE time_entry (
  EntryID int(11) NOT NULL auto_increment,
  EntryCreated datetime NOT NULL,
  Duration float(10,2) NOT NULL default '0.00',
  Description varchar(1000) default NULL,
  CategoryID int(11) NOT NULL default '0',
  EntryDate datetime default NULL,
  CreatorID varchar(50) NOT NULL,
  UserID varchar(50) NOT NULL,
  PRIMARY KEY  (EntryID),
  KEY CategoryID (CategoryID),
  KEY CreatorID (CreatorID),
  KEY UserID (UserID)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;

DROP TABLE IF EXISTS signon;
CREATE TABLE signon (
  SessionToken varchar(32) NOT NULL,
  Username varchar(50) NOT NULL,
  LastSignOnDate datetime NOT NULL,
  PRIMARY KEY  (SessionToken),
  KEY Username (Username)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

DROP TABLE IF EXISTS categories;
CREATE TABLE categories (
  CategoryID int(11) NOT NULL auto_increment,
  `Name` varchar(255) NOT NULL,
  ProjectID int(11) NOT NULL,
  ParentCategoryID int(11) default '0',
  Abbreviation varchar(255) default NULL,
  EstimateDuration float(10,2) default '0.00',
  PRIMARY KEY  (CategoryID),
  UNIQUE KEY UniqueNamePerProject (`Name`,ProjectID),
  KEY ProjectID (ProjectID)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;

DROP TABLE IF EXISTS project;
CREATE TABLE project (
  ProjectID int(11) NOT NULL auto_increment,
  `Name` varchar(255) NOT NULL,
  Description varchar(255) default NULL,
  CreationDate datetime NOT NULL,
  CompletionDate datetime NOT NULL,
  Disabled tinyint(1) NOT NULL default '0',
  EstimateDuration float(10,2) NOT NULL default '0.00',
  CreatorID varchar(50) NOT NULL,
  ManagerID varchar(50) default NULL,
  PRIMARY KEY  (ProjectID),
  KEY `Name` (`Name`),
  KEY CreatorID (CreatorID),
  KEY ManagerID (ManagerID)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;

DROP TABLE IF EXISTS users;
CREATE TABLE users (
  Username varchar(50) NOT NULL,
  `Password` varchar(50) NOT NULL,
  EmailAddress varchar(100) NOT NULL,
  Disabled tinyint(1) NOT NULL default '0',
  PRIMARY KEY  (Username)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

ALTER TABLE `categories`
  ADD CONSTRAINT categories_ibfk_1 
  	FOREIGN KEY (ProjectID) REFERENCES project (ProjectID);

ALTER TABLE `project`
  ADD CONSTRAINT project_ibfk_2 
  	FOREIGN KEY (ManagerID) REFERENCES users (Username),
  ADD CONSTRAINT project_ibfk_1 
  	FOREIGN KEY (CreatorID) REFERENCES users (Username);

ALTER TABLE `project_members`
  ADD CONSTRAINT project_members_ibfk_1 
  	FOREIGN KEY (UserID) REFERENCES users (Username),
  ADD CONSTRAINT project_members_ibfk_2 
  	FOREIGN KEY (ProjectID) REFERENCES project (ProjectID);

ALTER TABLE `signon`
  ADD CONSTRAINT signon_ibfk_1 
  	FOREIGN KEY (Username) REFERENCES users (Username);

ALTER TABLE `time_entry`
  ADD CONSTRAINT time_entry_ibfk_2 
  	FOREIGN KEY (UserID) REFERENCES users (Username),
  ADD CONSTRAINT time_entry_ibfk_1 
  	FOREIGN KEY (CategoryID) REFERENCES categories (CategoryID);

ALTER TABLE `user_roles`
  ADD CONSTRAINT user_roles_ibfk_2 
  	FOREIGN KEY (RoleType) REFERENCES role_types (RoleType),
  ADD CONSTRAINT user_roles_ibfk_1 
  	FOREIGN KEY (UserID) REFERENCES users (Username);

INSERT INTO role_types (RoleType, Description) VALUES 
('admin', 'Project administrator may additionally view the list of all users.'),
('consultant', 'Consultant may log time entries only.'),
('manager', 'Project manager may additionally edit all projects and view reports.');

INSERT INTO users (Username, Password, EmailAddress, Disabled) VALUES 
('admin', '21232f297a57a5a743894a0e4a801fc3', 'admin@pradosoft.com', 0),
('manager', '1d0258c2440a8d19e716292b231e3190', 'manager@pradosoft.com', 0),
('consultant', '7adfa4f2ba9323e6c1e024de375434b0', 'consultant@pradosoft.com', 0);

INSERT INTO user_roles (UserID, RoleType) VALUES 
('admin', 'admin'),
('admin', 'manager'),
('admin', 'consultant'),
('manager', 'manager'),
('manager', 'consultant'),
('consultant', 'consultant');