DataObjects/core.sql
[Pman.Core] / DataObjects / core.sql
1
2 CREATE TABLE Companies (
3   id int(11)  NOT NULL auto_increment,
4   PRIMARY KEY   (id)
5 );
6
7
8 ALTER TABLE Companies ADD COLUMN    code varchar(32)  NOT NULL DEFAULT '';;
9 ALTER TABLE Companies ADD COLUMN    name varchar(128)  default NULL ;
10 ALTER TABLE Companies ADD COLUMN    remarks text ;
11 ALTER TABLE Companies ADD COLUMN    owner_id int(11) NOT NULL DEFAULT 0 ;
12 ALTER TABLE Companies ADD COLUMN    address text ;
13 ALTER TABLE Companies ADD COLUMN    tel varchar(32)  default NULL;
14 ALTER TABLE Companies ADD COLUMN    fax varchar(32)  default NULL;
15 ALTER TABLE Companies ADD COLUMN    email varchar(128)  default NULL;
16 ALTER TABLE Companies ADD COLUMN    isOwner int(11) default NULL;
17 ALTER TABLE Companies ADD COLUMN    logo_id INT(11)  NOT NULL DEFAULT 0;;
18 ALTER TABLE Companies ADD COLUMN    background_color varchar(8)  NOT NULL;
19 ALTER TABLE Companies ADD COLUMN    comptype varchar(8)  NOT NULL DEFAULT '';
20 ALTER TABLE Companies ADD COLUMN    url varchar(254)  NOT NULL DEFAULT '';
21 ALTER TABLE Companies ADD COLUMN    main_office_id int(11)  NOT NULL DEFAULT 0;
22 ALTER TABLE Companies ADD COLUMN    created_by int(11)  NOT NULL DEFAULT 0;
23 ALTER TABLE Companies ADD COLUMN    created_dt datetime  NOT NULL;
24 ALTER TABLE Companies ADD COLUMN    updated_by int(11)  NOT NULL DEFAULT 0;
25 ALTER TABLE Companies ADD COLUMN    updated_dt datetime  NOT NULL;
26 ALTER TABLE Companies ADD COLUMN    passwd varchar(64) NOT NULL DEFAULT '';
27 ALTER TABLE Companies ADD COLUMN    dispatch_port varchar(255) NOT NULL DEFAULT '';
28 ALTER TABLE Companies ADD COLUMN    province varchar(255) NOT NULL DEFAULT '';
29 ALTER TABLE Companies ADD COLUMN    country varchar(4) NOT NULL DEFAULT '';
30
31
32 ALTER TABLE Companies CHANGE COLUMN isOwner isOwner int(11);
33 #postres
34 ALTER TABLE Companies ALTER isOwner TYPE int(11);
35 ALTER TABLE Companies ALTER owner_id SET DEFAULT 0;
36 ALTER TABLE Companies ALTER url SET DEFAULT '';
37
38
39 ALTER TABLE Companies ADD INDEX name_lookup (name);
40
41
42 UPDATE Companies set comptype='OWNER' where isOwner=1;
43
44 #// core comapy types - use core enums (Company Type)
45 DROP TABLE core_company_type;
46
47  
48 CREATE TABLE Events (
49   id int(11) NOT NULL auto_increment,
50   
51   PRIMARY KEY  (id)
52 ) ;
53
54
55
56 ALTER TABLE Events ADD COLUMN   person_name varchar(128)  default NULL;
57
58 ALTER TABLE Events ADD COLUMN   event_when DATETIME default NULL;
59 ALTER TABLE Events ADD COLUMN   action varchar(32)  default NULL;
60 ALTER TABLE Events ADD COLUMN   ipaddr varchar(16)  default NULL;
61 ALTER TABLE Events ADD COLUMN   on_id int(11) default NULL;
62 ALTER TABLE Events ADD COLUMN   on_table varchar(64)  default NULL;
63 ALTER TABLE Events ADD COLUMN   person_id int(11) default NULL;
64 ALTER TABLE Events ADD COLUMN   remarks text ;
65  
66
67 #very old code..
68 ALTER TABLE Events CHANGE COLUMN EventID id INT(11) AUTO_INCREMENT NOT NULL;
69
70 # this are for pre-postgres support code..
71 ALTER TABLE Events CHANGE COLUMN User person_name VARCHAR(128);
72 ALTER TABLE Events RENAME COLUMN User TO person_name;
73 ALTER TABLE Events CHANGE COLUMN Date event_when DATETIME ;
74 ALTER TABLE Events CHANGE COLUMN Event action VARCHAR(32);
75 ALTER TABLE Events CHANGE COLUMN Host ipaddr VARCHAR(16);
76 ALTER TABLE Events CHANGE COLUMN ItemID on_id INT(11);
77 ALTER TABLE Events CHANGE COLUMN Container on_table VARCHAR(64);
78
79
80 ALTER TABLE Events ADD INDEX lookup (on_id, on_table, person_id, event_when);
81
82
83
84
85
86 CREATE TABLE  core_event_audit  (
87     id int(11)  NOT NULL AUTO_INCREMENT,
88     PRIMARY KEY (id)
89 );
90
91 ALTER TABLE core_event_audit ADD COLUMN   event_id int(11)  NOT NULL DEFAULT 0;
92 ALTER TABLE core_event_audit ADD COLUMN       name varchar(128)  NOT NULL DEFAULT '';
93 ALTER TABLE core_event_audit ADD COLUMN       old_audit_id int(11)  NOT NULL DEFAULT 0;
94 ALTER TABLE core_event_audit ADD COLUMN       newvalue BLOB  NOT NULL DEFAULT '';
95 ALTER TABLE core_event_audit ADD   INDEX lookup(event_id, name, old_audit_id);
96
97 CREATE TABLE  Group_Members  (
98     id int(11)  NOT NULL AUTO_INCREMENT,
99     PRIMARY KEY (id)
100 );
101 ALTER TABLE Group_Members ADD COLUMN  group_id int(11) default NULL;
102 ALTER TABLE Group_Members ADD COLUMN   user_id int(11) NOT NULL default 0;
103
104 CREATE TABLE  Group_Rights  (
105     id int(11)  NOT NULL AUTO_INCREMENT,
106     PRIMARY KEY (id)
107 );
108 ALTER TABLE Group_Rights ADD COLUMN    rightname varchar(64)  NOT NULL DEFAULT '';
109 ALTER TABLE Group_Rights ADD COLUMN     group_id int(11) NOT NULL DEFAULT 0;
110 ALTER TABLE Group_Rights ADD COLUMN   accessmask varchar(10)  NOT NULL DEFAULT '';
111
112 #old mysql.
113 ALTER TABLE Group_Rights CHANGE COLUMN AccessMask accessmask varchar(10)  NOT NULL DEFAULT '';
114
115
116
117
118 CREATE TABLE Groups (
119   id int(11) NOT NULL auto_increment,  
120   PRIMARY KEY   (id)
121 );
122
123 ALTER TABLE Groups ADD COLUMN name varchar(64)  NOT NULL DEFAULT '';
124 ALTER TABLE Groups ADD COLUMN   type int(11) default NULL ;
125 ALTER TABLE Groups ADD COLUMN leader int(11)  NOT NULL default 0;
126 #old mysql..
127 ALTER TABLE Groups CHANGE COLUMN type type int(11) default 0;
128
129
130
131
132
133 CREATE TABLE Office (
134   id int(11) NOT NULL auto_increment,
135  
136   PRIMARY KEY  (id)
137 );
138
139
140 ALTER TABLE Office ADD COLUMN  company_id int(11) NOT NULL default '0';
141 ALTER TABLE Office ADD COLUMN    name varchar(64)  NOT NULL  DEFAULT '';
142 ALTER TABLE Office ADD COLUMN    address text ;
143 ALTER TABLE Office ADD COLUMN    phone varchar(32)  NOT NULL  DEFAULT '';
144 ALTER TABLE Office ADD COLUMN    fax varchar(32)  NOT NULL  DEFAULT '';
145 ALTER TABLE Office ADD COLUMN    email varchar(128)  NOT NULL  DEFAULT '';
146 ALTER TABLE Office ADD COLUMN    role varchar(32)  NOT NULL  DEFAULT '';
147
148
149 CREATE TABLE Person (
150   id int(11) NOT NULL auto_increment,
151   PRIMARY KEY  (id)
152 ) ;
153
154 ALTER TABLE Person ADD COLUMN   office_id int(11) default '0';
155 ALTER TABLE Person ADD COLUMN   name varchar(128)  NOT NULL  DEFAULT '';
156 ALTER TABLE Person ADD COLUMN   phone varchar(32)  NOT NULL  DEFAULT '';
157 ALTER TABLE Person ADD COLUMN   fax varchar(32)  NOT NULL DEFAULT '';
158 ALTER TABLE Person ADD COLUMN   email varchar(128)  NOT NULL DEFAULT '';
159 ALTER TABLE Person ADD COLUMN   company_id int(11) default '0';
160 ALTER TABLE Person ADD COLUMN   role varchar(254)  NOT NULL DEFAULT '';
161 ALTER TABLE Person ADD COLUMN   active int(11) NOT NULL  default 1;
162 ALTER TABLE Person ADD COLUMN   remarks text;
163 ALTER TABLE Person ADD COLUMN   passwd varchar(64) NOT NULL  DEFAULT '';
164 ALTER TABLE Person ADD COLUMN   owner_id int(11) NOT NULL DEFAULT 0;
165 ALTER TABLE Person ADD COLUMN   lang varchar(8) default 'en';
166 ALTER TABLE Person ADD COLUMN   no_reset_sent int(11) default '0';
167
168 ALTER TABLE Person ADD COLUMN   action_type VARCHAR(32) DEFAULT '';
169 ALTER TABLE Person ADD COLUMN   project_id int(11) default 0;
170 ALTER TABLE Person ADD COLUMN   deleted_by INT(11) NOT NULL default 0 ;
171 ALTER TABLE Person ADD COLUMN   deleted_dt DATETIME ;
172
173 # old mysql
174 alter table Person change column active active int(11) NOT NULL DEFAULT 1 ;
175 alter table Person change role role varchar(254) NOT NULL DEFAULT '';
176
177
178
179
180
181 CREATE TABLE Projects (
182   id int(11) NOT NULL auto_increment,
183   PRIMARY KEY  (id)
184   
185 ) ;
186
187
188
189 ALTER TABLE  Projects  ADD COLUMN name varchar(254)  NOT NULL  DEFAULT '';
190 ALTER TABLE  Projects  ADD COLUMN   remarks text ;
191 ALTER TABLE  Projects  ADD COLUMN   owner_id int(11) default NULL;
192 ALTER TABLE  Projects  ADD COLUMN   code varchar(32)  NOT NULL  DEFAULT '';
193 ALTER TABLE  Projects  ADD COLUMN   active int(11) default '1';
194 ALTER TABLE  Projects  ADD COLUMN   type varchar(1)  NOT NULL default 'P';
195 ALTER TABLE  Projects  ADD COLUMN   client_id int(11) NOT NULL default '0';
196 ALTER TABLE  Projects  ADD COLUMN   team_id int(11) NOT NULL default '0';
197 ALTER TABLE  Projects  ADD COLUMN file_location varchar(254)    NOT NULL default '';
198 ALTER TABLE  Projects  ADD COLUMN open_date date default NULL;
199 ALTER TABLE  Projects  ADD COLUMN open_by int(11) NOT NULL default '0';
200
201
202 # these should be removed, as they are code specific..
203 ALTER TABLE Projects ADD COLUMN countries varchar(128)  NOT NULL DEFAULT '';
204 ALTER TABLE Projects  ADD COLUMN languages varchar(128)  NOT NULL DEFAULT '';
205 ALTER TABLE  Projects ADD COLUMN agency_id int(11)  NOT NULL DEFAULT 0 ;
206
207 ALTER TABLE Projects ADD INDEX plookup (code);
208  
209
210 #-- we duplicate office_id and company_id here...
211 #-- not sure if we should keep doing that in the new design...
212 #-- we should improve our links code to handle this..
213
214
215 CREATE TABLE ProjectDirectory (
216   id int(11) NOT NULL auto_increment,
217   PRIMARY KEY  (id)
218 ) ;
219
220 ALTER TABLE  ProjectDirectory ADD COLUMN   project_id int(11) NOT NULL DEFAULT 0;
221 ALTER TABLE  ProjectDirectory ADD COLUMN   person_id int(11) NOT NULL DEFAULT 0;
222 ALTER TABLE  ProjectDirectory ADD COLUMN   ispm int(11) NOT NULL DEFAULT 0;
223 ALTER TABLE  ProjectDirectory ADD COLUMN   role varchar(16) NOT NULL DEFAULT '';
224
225 ALTER TABLE ProjectDirectory ADD INDEX plookup (project_id,person_id, ispm, role);
226
227
228 CREATE TABLE   Images (
229   id int(11) NOT NULL auto_increment,
230   PRIMARY KEY  (id)
231 );
232
233 ALTER TABLE Images    ADD COLUMN   filename varchar(255) NOT NULL default '';
234 ALTER TABLE Images    ADD COLUMN   ontable varchar(32) NOT NULL default '';
235 ALTER TABLE Images    ADD COLUMN   onid int(11) NOT NULL default '0';
236 ALTER TABLE Images    ADD COLUMN   mimetype varchar(64) NOT NULL default '';
237 ALTER TABLE Images    ADD COLUMN   width int(11) NOT NULL default '0';
238 ALTER TABLE Images    ADD COLUMN   height int(11) NOT NULL default '0';
239 ALTER TABLE Images    ADD COLUMN   filesize int(11) NOT NULL default '0';
240 ALTER TABLE Images    ADD COLUMN   displayorder int(11) NOT NULL default '0';
241 ALTER TABLE Images    ADD COLUMN   language varchar(6) NOT NULL default 'en';
242 ALTER TABLE Images    ADD COLUMN   parent_image_id int(11) NOT NULL default '0';
243
244 ALTER TABLE  Images ADD COLUMN created datetime ;
245 ALTER TABLE  Images ADD COLUMN imgtype VARCHAR(32) DEFAULT '' NOT NULL;
246 ALTER TABLE  Images ADD COLUMN linkurl VARCHAR(254) DEFAULT '' NOT NULL;
247 ALTER TABLE  Images ADD COLUMN descript TEXT DEFAULT '' NOT NULL;
248 ALTER TABLE  Images ADD COLUMN title VARCHAR(128) DEFAULT '' NOT NULL;
249
250
251 ALTER TABLE Images ADD INDEX lookup(ontable, onid);
252
253
254  
255 #// old core image type - merged into enum.
256 DROP TABLE core_image_type;
257
258
259 CREATE TABLE  i18n (
260   id int(11)  NOT NULL AUTO_INCREMENT,
261   PRIMARY KEY (id)
262   
263 );
264
265 ALTER TABLE  i18n ADD COLUMN   ltype varchar(1)  NOT NULL DEFAULT '';
266   ALTER TABLE  i18n ADD COLUMN   lkey varchar(8)  NOT NULL DEFAULT '';
267   ALTER TABLE  i18n ADD COLUMN   inlang varchar(8)  NOT NULL DEFAULT '';
268   ALTER TABLE  i18n ADD COLUMN   lval varchar(64)  NOT NULL DEFAULT '';
269   
270 ALTER TABLE i18n ADD INDEX lookup (ltype, lkey, inlang);
271
272                         
273         
274     
275 CREATE TABLE  core_locking (
276   int int(11)  NOT NULL AUTO_INCREMENT,
277   PRIMARY KEY (int)
278 );
279 ALTER TABLE  core_locking ADD COLUMN   on_table varchar(64)  NOT NULL DEFAULT '';
280 ALTER TABLE  core_locking ADD COLUMN    on_id int(11)  NOT NULL DEFAULT 0;
281 ALTER TABLE  core_locking ADD COLUMN  person_id int(11)  NOT NULL DEFAULT 0;
282 ALTER TABLE  core_locking ADD COLUMN  created datetime ;
283
284 alter table  core_locking ADD  INDEX lookup(on_table, on_id, person_id, created);
285  
286 # -- a generic enumeraction
287
288 CREATE TABLE   core_enum (
289   id int(11)  NOT NULL AUTO_INCREMENT,
290   PRIMARY KEY (id)
291  
292 );
293  
294 alter table  core_enum ADD COLUMN etype varchar(32)  NOT NULL DEFAULT '';
295 alter table  core_enum ADD COLUMN  name varchar(255)  NOT NULL DEFAULT '';
296 alter table  core_enum ADD COLUMN   active int(2)  NOT NULL DEFAULT 1;
297 alter table  core_enum ADD COLUMN  seqid int(11)  NOT NULL DEFAULT 0;
298 alter table  core_enum ADD COLUMN  seqmax int(11)  NOT NULL DEFAULT 0;
299
300 alter table  core_enum ADD  INDEX lookup(seqid, active, name, etype);
301
302 DELIMITER |
303
304 CREATE TRIGGER core_enum_insert AFTER INSERT ON core_enum
305 FOR EACH ROW BEGIN
306     CALL core_enum_seqmax(NEW.etype);
307 END;
308 |
309 DELIMITER ;
310
311 CREATE TRIGGER core_enum_update AFTER UDPATE ON core_enum
312 FOR EACH ROW BEGIN
313     CALL core_enum_seqmax(NEW.etype);
314 END;
315 |
316 DELIMITER ;
317
318
319 CREATE TABLE  translations (
320   id int(11)  NOT NULL AUTO_INCREMENT,
321   PRIMARY KEY (id)
322 );
323
324 alter table  translations ADD COLUMN    module varchar(64)  NOT NULL DEFAULT '';
325 alter table  translations ADD COLUMN    tfile varchar(128) NOT NULL DEFAULT '';
326 alter table  translations ADD COLUMN    tlang varchar(8)  NOT NULL DEFAULT '';
327 alter table  translations ADD COLUMN    tkey varchar(32)  NOT NULL DEFAULT '';
328 alter table  translations ADD COLUMN    tval longtext ;
329
330
331 ALTER TABLE translations ADD INDEX qlookup (module, tfile, tlang, tkey);
332
333
334 # - used to trigger emails about changes to items being watched.
335
336 CREATE TABLE core_watch (
337   id int(11)  NOT NULL AUTO_INCREMENT,
338   PRIMARY KEY (id)
339 ) ;
340
341
342 alter table  core_watch ADD COLUMN    ontable varchar(128) NOT NULL DEFAULT '';
343 alter table  core_watch ADD COLUMN   onid int(11) NOT NULL DEFAULT 0;
344 alter table  core_watch ADD COLUMN   person_id int(11) NOT NULL DEFAULT 0;
345 alter table  core_watch ADD COLUMN   event varchar(128) NOT NULL DEFAULT '';
346 alter table  core_watch ADD COLUMN   medium varchar(64) NOT NULL DEFAULT '';
347 alter table  core_watch ADD COLUMN  active int(11) NOT NULL DEFAULT '1';
348
349 ALTER TABLE core_watch ADD INDEX qlookup (ontable,onid,person_id,event,medium);
350
351
352
353
354 CREATE TABLE  core_notify  (
355   id int(11)  NOT NULL AUTO_INCREMENT,
356   PRIMARY KEY (id)
357 );
358
359 ALTER TABLE core_notify ADD COLUMN   act_when DATETIME ;
360 ALTER TABLE core_notify ADD COLUMN    act_start DATETIME ;
361 ALTER TABLE core_notify ADD COLUMN  onid int(11)  NOT NULL DEFAULT 0;
362 ALTER TABLE core_notify ADD COLUMN  ontable varchar(128)  NOT NULL DEFAULT '';
363 ALTER TABLE core_notify ADD COLUMN  person_id int(11)  NOT NULL DEFAULT 0;
364 ALTER TABLE core_notify ADD COLUMN  msgid varchar(128)  NOT NULL  DEFAULT '';
365 ALTER TABLE core_notify ADD COLUMN  sent DATETIME ;
366 ALTER TABLE core_notify ADD COLUMN  event_id int(11)  NOT NULL DEFAULT 0;
367 ALTER TABLE core_notify ADD COLUMN  watch_id INT(11) NOT NULL DEFAULT 0;
368 ALTER TABLE core_notify ADD COLUMN  trigger_person_id INT(11) NOT NULL DEFAULT 0;
369 ALTER TABLE core_notify ADD COLUMN  trigger_event_id INT(11) NOT NULL DEFAULT 0;
370 ALTER TABLE core_notify ADD   INDEX lookup(act_when, msgid);
371 #old mysql..
372 ALTER TABLE core_notify CHANGE COLUMN bounced event_id INT(11) NOT NULL DEFAULT 0;
373   
374
375
376
377 # - used by email / tracker to handle alises - we have to be carefull adding to this table...
378
379 CREATE TABLE core_person_alias (
380   id int(11)  NOT NULL AUTO_INCREMENT,
381
382   PRIMARY KEY (id)
383 ) ;
384 ALTER TABLE core_person_alias ADD COLUMN   person_id varchar(128) DEFAULT NULL;
385 ALTER TABLE core_person_alias ADD COLUMN  alias varchar(254) NOT NULL DEFAULT '';
386   
387 ALTER TABLE core_person_alias ADD INDEX alias (alias);