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   person_table varchar(64) default NULL;
65
66 ALTER TABLE Events ADD COLUMN   remarks text ;
67  
68
69 --#very old code..
70 ALTER TABLE Events CHANGE COLUMN EventID id INT(11) AUTO_INCREMENT NOT NULL;
71
72 --# this are for pre-postgres support code..
73 ALTER TABLE Events CHANGE COLUMN User person_name VARCHAR(128);
74 ALTER TABLE Events RENAME COLUMN User TO person_name;
75 ALTER TABLE Events CHANGE COLUMN Date event_when DATETIME ;
76 ALTER TABLE Events CHANGE COLUMN Event action VARCHAR(32);
77 ALTER TABLE Events CHANGE COLUMN Host ipaddr VARCHAR(16);
78 ALTER TABLE Events CHANGE COLUMN ItemID on_id INT(11);
79 ALTER TABLE Events CHANGE COLUMN Container on_table VARCHAR(64);
80
81
82 ALTER TABLE Events ADD INDEX lookup (on_id, on_table, person_id, event_when);
83
84 ALTER TABLE Events ADD INDEX lookupf (on_id, action, on_table, person_id, event_when);
85
86 ALTER TABLE Events ADD INDEX lookuppt ( person_table);
87
88 --# speeding up lookups. 
89 ALTER TABLE Events ADD INDEX lookup_when( person_id, event_id );
90
91 ALTER TABLE Events add index lookup_event_when (event_when);
92 ALTER TABLE Events add index lookup_action (action);
93 ALTER TABLE Events add index lookup_on_table (on_table);
94
95 ALTER TABLE Events add index lookup_action_person (action, person_id);
96
97
98 CREATE TABLE  core_event_audit  (
99     id int(11)  NOT NULL AUTO_INCREMENT,
100     PRIMARY KEY (id)
101 );
102
103 ALTER TABLE core_event_audit ADD COLUMN   event_id int(11)  NOT NULL DEFAULT 0;
104 ALTER TABLE core_event_audit ADD COLUMN       name varchar(128)  NOT NULL DEFAULT '';
105 ALTER TABLE core_event_audit ADD COLUMN       old_audit_id int(11)  NOT NULL DEFAULT 0;
106 ALTER TABLE core_event_audit ADD COLUMN       newvalue BLOB  NOT NULL DEFAULT '';
107 ALTER TABLE core_event_audit ADD   INDEX lookup(event_id, name, old_audit_id);
108
109 CREATE TABLE  Group_Members  (
110     id int(11)  NOT NULL AUTO_INCREMENT,
111     PRIMARY KEY (id)
112 );
113 ALTER TABLE Group_Members ADD COLUMN  group_id int(11) default NULL;
114 ALTER TABLE Group_Members ADD COLUMN   user_id int(11) NOT NULL default 0;
115
116 CREATE TABLE  Group_Rights  (
117     id int(11)  NOT NULL AUTO_INCREMENT,
118     PRIMARY KEY (id)
119 );
120 ALTER TABLE Group_Rights ADD COLUMN    rightname varchar(64)  NOT NULL DEFAULT '';
121 ALTER TABLE Group_Rights ADD COLUMN     group_id int(11) NOT NULL DEFAULT 0;
122 ALTER TABLE Group_Rights ADD COLUMN   accessmask varchar(10)  NOT NULL DEFAULT '';
123
124 #old mysql.
125 ALTER TABLE Group_Rights CHANGE COLUMN AccessMask accessmask varchar(10)  NOT NULL DEFAULT '';
126
127
128
129
130 CREATE TABLE Groups (
131   id int(11) NOT NULL auto_increment,  
132   PRIMARY KEY   (id)
133 );
134
135 ALTER TABLE Groups ADD COLUMN name varchar(64)  NOT NULL DEFAULT '';
136 ALTER TABLE Groups ADD COLUMN   type int(11) default NULL ;
137 ALTER TABLE Groups ADD COLUMN leader int(11)  NOT NULL default 0;
138 #old mysql..
139 ALTER TABLE Groups CHANGE COLUMN type type int(11) default 0;
140
141
142
143
144
145 CREATE TABLE Office (
146   id int(11) NOT NULL auto_increment,
147  
148   PRIMARY KEY  (id)
149 );
150
151
152 ALTER TABLE Office ADD COLUMN  company_id int(11) NOT NULL default '0';
153 ALTER TABLE Office ADD COLUMN    name varchar(64)  NOT NULL  DEFAULT '';
154 ALTER TABLE Office ADD COLUMN    address text ;
155 ALTER TABLE Office ADD COLUMN    phone varchar(32)  NOT NULL  DEFAULT '';
156 ALTER TABLE Office ADD COLUMN    fax varchar(32)  NOT NULL  DEFAULT '';
157 ALTER TABLE Office ADD COLUMN    email varchar(128)  NOT NULL  DEFAULT '';
158 ALTER TABLE Office ADD COLUMN    role varchar(32)  NOT NULL  DEFAULT '';
159
160
161 CREATE TABLE Person (
162   id int(11) NOT NULL auto_increment,
163   PRIMARY KEY  (id)
164 ) ;
165
166 ALTER TABLE Person ADD COLUMN   office_id int(11) default '0';
167 ALTER TABLE Person ADD COLUMN   name varchar(128)  NOT NULL  DEFAULT '';
168 ALTER TABLE Person ADD COLUMN   phone varchar(32)  NOT NULL  DEFAULT '';
169 ALTER TABLE Person ADD COLUMN   fax varchar(32)  NOT NULL DEFAULT '';
170 ALTER TABLE Person ADD COLUMN   email varchar(128)  NOT NULL DEFAULT '';
171 ALTER TABLE Person ADD COLUMN   company_id int(11) default '0';
172 ALTER TABLE Person ADD COLUMN   role varchar(254)  NOT NULL DEFAULT '';
173 ALTER TABLE Person ADD COLUMN   active int(11) NOT NULL  default 1;
174 ALTER TABLE Person ADD COLUMN   remarks text;
175 ALTER TABLE Person ADD COLUMN   passwd varchar(64) NOT NULL  DEFAULT '';
176 ALTER TABLE Person ADD COLUMN   owner_id int(11) NOT NULL DEFAULT 0;
177 ALTER TABLE Person ADD COLUMN   lang varchar(8) default 'en';
178 ALTER TABLE Person ADD COLUMN   no_reset_sent int(11) default '0';
179
180 ALTER TABLE Person ADD COLUMN   action_type VARCHAR(32) DEFAULT '';
181 ALTER TABLE Person ADD COLUMN   project_id int(11) default 0;
182 ALTER TABLE Person ADD COLUMN   deleted_by INT(11) NOT NULL default 0 ;
183 ALTER TABLE Person ADD COLUMN   deleted_dt DATETIME ;
184
185 ALTER TABLE Person ADD COLUMN   firstname varchar(128);
186 ALTER TABLE Person ADD COLUMN   lastname varchar(128);
187
188
189
190 # old mysql
191 alter table Person change column active active int(11) NOT NULL DEFAULT 1 ;
192 alter table Person change role role varchar(254) NOT NULL DEFAULT '';
193
194
195
196
197
198 CREATE TABLE Projects (
199   id int(11) NOT NULL auto_increment,
200   PRIMARY KEY  (id)
201   
202 ) ;
203
204
205
206 ALTER TABLE  Projects  ADD COLUMN name varchar(254)  NOT NULL  DEFAULT '';
207 ALTER TABLE  Projects  ADD COLUMN   remarks text ;
208 ALTER TABLE  Projects  ADD COLUMN   owner_id int(11) default NULL;
209 ALTER TABLE  Projects  ADD COLUMN   code varchar(32)  NOT NULL  DEFAULT '';
210 ALTER TABLE  Projects  ADD COLUMN   active int(11) default '1';
211 ALTER TABLE  Projects  ADD COLUMN   type varchar(1)  NOT NULL default 'P';
212 ALTER TABLE  Projects  ADD COLUMN   client_id int(11) NOT NULL default '0';
213 ALTER TABLE  Projects  ADD COLUMN   team_id int(11) NOT NULL default '0';
214 ALTER TABLE  Projects  ADD COLUMN file_location varchar(254)    NOT NULL default '';
215 ALTER TABLE  Projects  ADD COLUMN open_date date default NULL;
216 ALTER TABLE  Projects  ADD COLUMN open_by int(11) NOT NULL default '0';
217 ALTER TABLE  Projects  ADD COLUMN updated_dt DATETIME NOT NULL;
218
219 # these should be removed, as they are code specific..
220 ALTER TABLE Projects ADD COLUMN countries varchar(128)  NOT NULL DEFAULT '';
221 ALTER TABLE Projects  ADD COLUMN languages varchar(128)  NOT NULL DEFAULT '';
222 ALTER TABLE  Projects ADD COLUMN agency_id int(11)  NOT NULL DEFAULT 0 ;
223
224 ALTER TABLE Projects ADD INDEX plookup (code);
225  
226
227 #-- we duplicate office_id and company_id here...
228 #-- not sure if we should keep doing that in the new design...
229 #-- we should improve our links code to handle this..
230
231
232 CREATE TABLE ProjectDirectory (
233   id int(11) NOT NULL auto_increment,
234   PRIMARY KEY  (id)
235 ) ;
236
237 ALTER TABLE  ProjectDirectory ADD COLUMN   project_id int(11) NOT NULL DEFAULT 0;
238 ALTER TABLE  ProjectDirectory ADD COLUMN   person_id int(11) NOT NULL DEFAULT 0;
239 ALTER TABLE  ProjectDirectory ADD COLUMN   ispm int(11) NOT NULL DEFAULT 0;
240 ALTER TABLE  ProjectDirectory ADD COLUMN   role varchar(16) NOT NULL DEFAULT '';
241
242 ALTER TABLE ProjectDirectory ADD INDEX plookup (project_id,person_id, ispm, role);
243
244
245 CREATE TABLE   Images (
246   id int(11) NOT NULL auto_increment,
247   PRIMARY KEY  (id)
248 );
249
250 ALTER TABLE Images    ADD COLUMN   filename varchar(255) NOT NULL default '';
251 ALTER TABLE Images    ADD COLUMN   ontable varchar(32) NOT NULL default '';
252 ALTER TABLE Images    ADD COLUMN   onid int(11) NOT NULL default '0';
253 ALTER TABLE Images    ADD COLUMN   mimetype varchar(64) NOT NULL default '';
254 ALTER TABLE Images    ADD COLUMN   width int(11) NOT NULL default '0';
255 ALTER TABLE Images    ADD COLUMN   height int(11) NOT NULL default '0';
256 ALTER TABLE Images    ADD COLUMN   filesize int(11) NOT NULL default '0';
257 ALTER TABLE Images    ADD COLUMN   displayorder int(11) NOT NULL default '0';
258 ALTER TABLE Images    ADD COLUMN   language varchar(6) NOT NULL default 'en';
259 ALTER TABLE Images    ADD COLUMN   parent_image_id int(11) NOT NULL default '0';
260
261 ALTER TABLE  Images ADD COLUMN created datetime ;
262 ALTER TABLE  Images ADD COLUMN imgtype VARCHAR(32) DEFAULT '' NOT NULL;
263 ALTER TABLE  Images ADD COLUMN linkurl VARCHAR(254) DEFAULT '' NOT NULL;
264 ALTER TABLE  Images ADD COLUMN descript TEXT DEFAULT '' NOT NULL;
265 ALTER TABLE  Images ADD COLUMN title VARCHAR(128) DEFAULT '' NOT NULL;
266
267
268 ALTER TABLE Images ADD INDEX lookup(ontable, onid);
269
270
271  
272 #// old core image type - merged into enum.
273 DROP TABLE core_image_type;
274
275
276 CREATE TABLE  i18n (
277   id int(11)  NOT NULL AUTO_INCREMENT,
278   PRIMARY KEY (id)
279   
280 );
281
282 ALTER TABLE  i18n ADD COLUMN   ltype varchar(1)  NOT NULL DEFAULT '';
283   ALTER TABLE  i18n ADD COLUMN   lkey varchar(8)  NOT NULL DEFAULT '';
284   ALTER TABLE  i18n ADD COLUMN   inlang varchar(8)  NOT NULL DEFAULT '';
285   ALTER TABLE  i18n ADD COLUMN   lval varchar(64)  NOT NULL DEFAULT '';
286   
287 ALTER TABLE i18n ADD INDEX lookup (ltype, lkey, inlang);
288
289                         
290         
291     
292 CREATE TABLE  core_locking (
293   id int(11)  NOT NULL AUTO_INCREMENT,
294   PRIMARY KEY (id)
295 );
296 ALTER TABLE  core_locking ADD COLUMN   on_table varchar(64)  NOT NULL DEFAULT '';
297 ALTER TABLE  core_locking ADD COLUMN    on_id int(11)  NOT NULL DEFAULT 0;
298 ALTER TABLE  core_locking ADD COLUMN  person_id int(11)  NOT NULL DEFAULT 0;
299 ALTER TABLE  core_locking ADD COLUMN  created datetime ;
300
301 alter table  core_locking ADD  INDEX lookup(on_table, on_id, person_id, created);
302 # -- oops... - wrong name of pid.
303 alter table  core_locking change column `int` id int(11) auto_increment not null;
304
305 # -- a generic enumeraction
306
307 CREATE TABLE   core_enum (
308   id int(11)  NOT NULL AUTO_INCREMENT,
309   PRIMARY KEY (id)
310  
311 );
312  
313 alter table  core_enum ADD COLUMN etype varchar(32)  NOT NULL DEFAULT '';
314 alter table  core_enum ADD COLUMN  name varchar(255)  NOT NULL DEFAULT '';
315 alter table  core_enum ADD COLUMN   active int(2)  NOT NULL DEFAULT 1;
316 alter table  core_enum ADD COLUMN  seqid int(11)  NOT NULL DEFAULT 0;
317 alter table  core_enum ADD COLUMN  seqmax int(11)  NOT NULL DEFAULT 0;
318
319 alter table  core_enum ADD  INDEX lookup(seqid, active, name, etype);
320  
321
322
323
324 CREATE TABLE  translations (
325   id int(11)  NOT NULL AUTO_INCREMENT,
326   PRIMARY KEY (id)
327 );
328
329 alter table  translations ADD COLUMN    module varchar(64)  NOT NULL DEFAULT '';
330 alter table  translations ADD COLUMN    tfile varchar(128) NOT NULL DEFAULT '';
331 alter table  translations ADD COLUMN    tlang varchar(8)  NOT NULL DEFAULT '';
332 alter table  translations ADD COLUMN    tkey varchar(32)  NOT NULL DEFAULT '';
333 alter table  translations ADD COLUMN    tval longtext ;
334
335
336 ALTER TABLE translations ADD INDEX qlookup (module, tfile, tlang, tkey);
337
338
339 # - used to trigger emails about changes to items being watched.
340
341 CREATE TABLE core_watch (
342   id int(11)  NOT NULL AUTO_INCREMENT,
343   PRIMARY KEY (id)
344 ) ;
345
346
347 alter table  core_watch ADD COLUMN    ontable varchar(128) NOT NULL DEFAULT '';
348 alter table  core_watch ADD COLUMN   onid int(11) NOT NULL DEFAULT 0;
349 alter table  core_watch ADD COLUMN   person_id int(11) NOT NULL DEFAULT 0;
350 alter table  core_watch ADD COLUMN   event varchar(128) NOT NULL DEFAULT '';
351 alter table  core_watch ADD COLUMN   medium varchar(64) NOT NULL DEFAULT '';
352 alter table  core_watch ADD COLUMN  active int(11) NOT NULL DEFAULT '1';
353
354 ALTER TABLE core_watch ADD INDEX qlookup (ontable,onid,person_id,event,medium);
355
356
357
358
359 CREATE TABLE  core_notify  (
360   id int(11)  NOT NULL AUTO_INCREMENT,
361   PRIMARY KEY (id)
362 );
363 ALTER TABLE core_notify ADD COLUMN  evtype VARCHAR(128) NOT NULL default '';
364 ALTER TABLE core_notify ADD COLUMN  recur_id INT(11) NOT NULL default 0;
365 ALTER TABLE core_notify ADD COLUMN  act_when DATETIME ;
366 ALTER TABLE core_notify ADD COLUMN  act_start DATETIME ;
367 ALTER TABLE core_notify ADD COLUMN  onid int(11)  NOT NULL DEFAULT 0;
368 ALTER TABLE core_notify ADD COLUMN  ontable varchar(128)  NOT NULL DEFAULT '';
369 ALTER TABLE core_notify ADD COLUMN  person_id int(11)  NOT NULL DEFAULT 0;
370 ALTER TABLE core_notify ADD COLUMN  msgid varchar(128)  NOT NULL  DEFAULT '';
371
372 ALTER TABLE core_notify ADD COLUMN  sent DATETIME ;
373 ALTER TABLE core_notify ADD COLUMN  event_id int(11)  NOT NULL DEFAULT 0;
374 ALTER TABLE core_notify ADD COLUMN  watch_id INT(11) NOT NULL DEFAULT 0;
375 ALTER TABLE core_notify ADD COLUMN  trigger_person_id INT(11) NOT NULL DEFAULT 0;
376 ALTER TABLE core_notify ADD COLUMN  trigger_event_id INT(11) NOT NULL DEFAULT 0;
377 ALTER TABLE core_notify ADD   INDEX lookup(act_when, msgid);
378 ALTER TABLE core_notify ADD COLUMN  to_email varchar(255)  NOT NULL  DEFAULT '';
379 ALTER TABLE core_notify ADD   INDEX lookup_a(onid, ontable, person_id, act_when, msgid, to_email);
380
381 #old mysql..
382 ALTER TABLE core_notify CHANGE COLUMN bounced event_id INT(11) NOT NULL DEFAULT 0;
383   
384
385
386
387 # - used by email / tracker to handle alises - we have to be carefull adding to this table...
388
389 CREATE TABLE core_person_alias (
390   id int(11)  NOT NULL AUTO_INCREMENT,
391
392   PRIMARY KEY (id)
393 ) ;
394 ALTER TABLE core_person_alias ADD COLUMN   person_id varchar(128) DEFAULT NULL;
395 ALTER TABLE core_person_alias ADD COLUMN  alias varchar(254) NOT NULL DEFAULT '';
396   
397 ALTER TABLE core_person_alias ADD INDEX alias (alias);
398
399
400
401 CREATE TABLE core_notify_recur (
402   id int(11)  NOT NULL AUTO_INCREMENT,
403
404   PRIMARY KEY (id)
405 ) ;
406  
407
408 ALTER TABLE  core_notify_recur  ADD COLUMN person_id int(11)  NOT NULL;
409 ALTER TABLE  core_notify_recur  ADD COLUMN dtstart datetime  NOT NULL;
410 ALTER TABLE  core_notify_recur  ADD COLUMN dtend datetime  NOT NULL;
411 ALTER TABLE  core_notify_recur  ADD COLUMN max_applied_dt datetime  NOT NULL;
412 ALTER TABLE  core_notify_recur  ADD COLUMN updated_dt datetime  NOT NULL;
413 ALTER TABLE  core_notify_recur  ADD COLUMN last_applied_dt datetime  NOT NULL;
414 ALTER TABLE  core_notify_recur  ADD COLUMN tz varchar(64)  NOT NULL;
415  
416 ALTER TABLE  core_notify_recur  ADD COLUMN freq varchar(8) NOT NULL;
417 ALTER TABLE  core_notify_recur  ADD COLUMN freq_day text NOT NULL;
418 ALTER TABLE  core_notify_recur  ADD COLUMN freq_hour text  NOT NULL;
419
420 ALTER TABLE  core_notify_recur  ADD COLUMN onid int(11)  NOT NULL default 0;
421 ALTER TABLE  core_notify_recur  ADD COLUMN ontable varchar(128)  NOT NULL default '';
422 ALTER TABLE  core_notify_recur  ADD COLUMN last_event_id  int(11)  default 0;
423 ALTER TABLE  core_notify_recur  ADD COLUMN method varchar(128) default '';     
424
425
426 ALTER TABLE  core_notify_recur  ADD INDEX lookup(person_id, dtstart, dtend, tz, max_applied_dt, updated_dt, last_applied_dt);
427
428 -- old design..
429 ALTER TABLE  core_notify_recur  CHANGE COLUMN tz  tz varchar(64)  NOT NULL;
430  
431