Remove outdated ckeditor library and fonts.
[openemr.git] / sql / 5_0_0-to-5_0_1_upgrade.sql
blobeb7df04c1b04fc65f24c93b066a3ec5d01801fd2
1 --
2 --  Comment Meta Language Constructs:
3 --
4 --  #IfNotTable
5 --    argument: table_name
6 --    behavior: if the table_name does not exist,  the block will be executed
8 --  #IfTable
9 --    argument: table_name
10 --    behavior: if the table_name does exist, the block will be executed
12 --  #IfColumn
13 --    arguments: table_name colname
14 --    behavior:  if the table and column exist,  the block will be executed
16 --  #IfMissingColumn
17 --    arguments: table_name colname
18 --    behavior:  if the table exists but the column does not,  the block will be executed
20 --  #IfNotColumnType
21 --    arguments: table_name colname value
22 --    behavior:  If the table table_name does not have a column colname with a data type equal to value, then the block will be executed
24 --  #IfNotRow
25 --    arguments: table_name colname value
26 --    behavior:  If the table table_name does not have a row where colname = value, the block will be executed.
28 --  #IfNotRow2D
29 --    arguments: table_name colname value colname2 value2
30 --    behavior:  If the table table_name does not have a row where colname = value AND colname2 = value2, the block will be executed.
32 --  #IfNotRow3D
33 --    arguments: table_name colname value colname2 value2 colname3 value3
34 --    behavior:  If the table table_name does not have a row where colname = value AND colname2 = value2 AND colname3 = value3, the block will be executed.
36 --  #IfNotRow4D
37 --    arguments: table_name colname value colname2 value2 colname3 value3 colname4 value4
38 --    behavior:  If the table table_name does not have a row where colname = value AND colname2 = value2 AND colname3 = value3 AND colname4 = value4, the block will be executed.
40 --  #IfNotRow2Dx2
41 --    desc:      This is a very specialized function to allow adding items to the list_options table to avoid both redundant option_id and title in each element.
42 --    arguments: table_name colname value colname2 value2 colname3 value3
43 --    behavior:  The block will be executed if both statements below are true:
44 --               1) The table table_name does not have a row where colname = value AND colname2 = value2.
45 --               2) The table table_name does not have a row where colname = value AND colname3 = value3.
47 --  #IfRow2D
48 --    arguments: table_name colname value colname2 value2
49 --    behavior:  If the table table_name does have a row where colname = value AND colname2 = value2, the block will be executed.
51 --  #IfRow3D
52 --        arguments: table_name colname value colname2 value2 colname3 value3
53 --        behavior:  If the table table_name does have a row where colname = value AND colname2 = value2 AND colname3 = value3, the block will be executed.
55 --  #IfIndex
56 --    desc:      This function is most often used for dropping of indexes/keys.
57 --    arguments: table_name colname
58 --    behavior:  If the table and index exist the relevant statements are executed, otherwise not.
60 --  #IfNotIndex
61 --    desc:      This function will allow adding of indexes/keys.
62 --    arguments: table_name colname
63 --    behavior:  If the index does not exist, it will be created
65 --  #EndIf
66 --    all blocks are terminated with a #EndIf statement.
68 --  #IfNotListReaction
69 --    Custom function for creating Reaction List
71 --  #IfNotListOccupation
72 --    Custom function for creating Occupation List
74 --  #IfTextNullFixNeeded
75 --    desc: convert all text fields without default null to have default null.
76 --    arguments: none
78 --  #IfTableEngine
79 --    desc:      Execute SQL if the table has been created with given engine specified.
80 --    arguments: table_name engine
81 --    behavior:  Use when engine conversion requires more than one ALTER TABLE
83 --  #IfInnoDBMigrationNeeded
84 --    desc: find all MyISAM tables and convert them to InnoDB.
85 --    arguments: none
86 --    behavior: can take a long time.
88 #IfMissingColumn list_options edit_options
89   ALTER TABLE `list_options` ADD `edit_options` TINYINT(1) NOT NULL DEFAULT '1';
90 #Endif
92 #IfMissingColumn list_options timestamp
93 ALTER TABLE `list_options` ADD `timestamp` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ;
94 #Endif
96 #IfNotTable multiple_db
97   CREATE TABLE `multiple_db` (
98     `id` int(11) NOT NULL AUTO_INCREMENT,
99     `namespace` varchar(255) NOT NULL,
100     `username` varchar(255) NOT NULL,
101     `password` text,
102     `dbname` varchar(255) NOT NULL,
103     `host` varchar(255) NOT NULL DEFAULT 'localhost',
104     `port` smallint(4) NOT NULL DEFAULT '3306',
105     `date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
106      UNIQUE KEY `namespace` (namespace),
107      PRIMARY KEY (id)
108   ) ENGINE=InnoDB;
109 #EndIf
111 #IfNotRow2D list_options list_id page_validation option_id therapy_groups_add#addGroup
112 INSERT INTO `list_options` (`list_id`, `option_id`, `title`, `seq`, `notes`, `activity`) VALUES ('page_validation', 'therapy_groups_add#addGroup', '/interface/therapy_groups/index.php?method=addGroup', 120, '{group_name:{presence: true}}', 1);
113 #EndIf
115 #IfNotRow2D list_options list_id page_validation option_id therapy_groups_edit#editGroup
116 INSERT INTO `list_options` (`list_id`, `option_id`, `title`, `seq`, `notes`, `activity`) VALUES ('page_validation', 'therapy_groups_edit#editGroup', '/interface/therapy_groups/index.php?method=groupDetails', 125, '{group_name:{presence: true}}', 1);
117 #EndIf
119 #IfNotRow2D list_options list_id page_validation option_id tg_add#add-participant-form
120 INSERT INTO `list_options` (`list_id`, `option_id`, `title`, `seq`, `notes`, `activity`) VALUES ('page_validation', 'tg_add#add-participant-form', '/interface/therapy_groups/index.php?method=groupParticipants', 130, '{participant_name:{presence: true}, group_patient_start:{presence: true}}', 1);
121 #EndIf
123 #IfNotRow2D list_options list_id page_validation option_id add_edit_event#theform_groups
124 INSERT INTO `list_options` (`list_id`,`option_id`,`title`,`seq`,`is_default`,`option_value`,`mapping`,`notes`,`codes`,`toggle_setting_1`,`toggle_setting_2`,`activity`,`subtype`)
125 VALUES ('page_validation','add_edit_event#theform_groups','/interface/main/calendar/add_edit_event.php?group=true',150,0,0,'','{form_group:{presence: true}}','',0,0,1,'');
126 #EndIf
128 #IfNotRow2D list_options list_id page_validation option_id common#new-encounter-form
129 INSERT INTO `list_options` (`list_id`, `option_id`, `title`, `seq`, `notes`, `activity`) VALUES ('page_validation', 'common#new-encounter-form', '/interface/forms/newGroupEncounter/common.php', 160, '{pc_catid:{exclusion: ["_blank"]}}', 1);
130 #EndIf
133 #IfNotTable therapy_groups
134 CREATE TABLE `therapy_groups` (
135   `group_id` int(11) NOT NULL auto_increment,
136   `group_name` varchar(255) NOT NULL ,
137   `group_start_date` date NOT NULL ,
138   `group_end_date` date,
139   `group_type` tinyint NOT NULL,
140   `group_participation` tinyint NOT NULL,
141   `group_status` int(11) NOT NULL,
142   `group_notes` text,
143   `group_guest_counselors` varchar(255),
144   PRIMARY KEY  (`group_id`)
145 ) ENGINE=InnoDB;
146 #EndIf
148 #IfNotTable therapy_groups_participants
149 CREATE TABLE `therapy_groups_participants` (
150   `group_id` int(11) NOT NULL,
151   `pid` int(11) NOT NULL ,
152   `group_patient_status` int(11) NOT NULL,
153   `group_patient_start` date NOT NULL ,
154   `group_patient_end` date,
155   `group_patient_comment` text,
156   PRIMARY KEY (`group_id`,`pid`)
157 ) ENGINE=InnoDB;
158 #EndIf
160 #IfNotTable therapy_groups_participant_attendance
161 CREATE TABLE `therapy_groups_participant_attendance` (
162   `form_id` int(11) NOT NULL,
163   `pid` int(11) NOT NULL ,
164   `meeting_patient_comment` text ,
165   `meeting_patient_status` varchar(15),
166   PRIMARY KEY (`form_id`,`pid`)
167 ) ENGINE=InnoDB;
168 #EndIf
170 #IfNotTable therapy_groups_counselors
171 CREATE TABLE `therapy_groups_counselors`(
172         `group_id` int(11) NOT NULL,
173         `user_id` int(11) NOT NULL,
174         PRIMARY KEY (`group_id`,`user_id`)
175 ) ENGINE=InnoDB;
176 #EndIf
178 #IfMissingColumn openemr_postcalendar_events pc_gid
179 ALTER TABLE openemr_postcalendar_events ADD pc_gid int(11) DEFAULT 0;
180 #EndIf
182 #IfNotRow2D list_options list_id lists option_id groupstat
183 INSERT INTO list_options (`list_id`, `option_id`, `title`, `seq`, `is_default`, `option_value`) VALUES ('lists', 'groupstat', 'Group Statuses', '13', '0', '0');
184 INSERT INTO list_options (`list_id`, `option_id`, `title`, `seq`, `is_default`, `option_value`, `notes`) VALUES ('groupstat', '-', '- None', '10', '0', '0', 'FEFDCF|0');
185 INSERT INTO list_options (`list_id`, `option_id`, `title`, `seq`, `is_default`, `option_value`, `notes`) VALUES ('groupstat', '=', '= Took Place', '20', '0', '0', 'FF2414|0');
186 INSERT INTO list_options (`list_id`, `option_id`, `title`, `seq`, `is_default`, `option_value`, `notes`) VALUES ('groupstat', '>', '> Did Not Take Place', '30', '0', '0', 'BFBFBF|0');
187 INSERT INTO list_options (`list_id`, `option_id`, `title`, `seq`, `is_default`, `option_value`, `notes`) VALUES ('groupstat', '<', '< Not Reported', '40', '0', '0', 'FEFDCF|0');
188 #EndIf
190 #IfNotRow openemr_postcalendar_categories pc_catname Group Therapy
191 INSERT INTO openemr_postcalendar_categories (`pc_catname`, `pc_catcolor`, `pc_recurrspec`, `pc_duration` ,`pc_cattype` , `pc_active` , `pc_seq`)
192 VALUES ('Group Therapy' , '#BFBFBF' , 'a:5:{s:17:"event_repeat_freq";s:1:"0";s:22:"event_repeat_freq_type";s:1:"0";s:19:"event_repeat_on_num";s:1:"1";s:19:"event_repeat_on_day";s:1:"0";s:20:"event_repeat_on_freq";s:1:"0";}', '3600', '3', '1', '90');
193 #EndIf
196 #IfNotTable form_groups_encounter
197 CREATE TABLE `form_groups_encounter` (
198   `id` bigint(20) NOT NULL auto_increment,
199   `date` datetime default NULL,
200   `reason` longtext,
201   `facility` longtext,
202   `facility_id` int(11) NOT NULL default '0',
203   `group_id` bigint(20) default NULL,
204   `encounter` bigint(20) default NULL,
205   `onset_date` datetime default NULL,
206   `sensitivity` varchar(30) default NULL,
207   `billing_note` text,
208   `pc_catid` int(11) NOT NULL default '5' COMMENT 'event category from openemr_postcalendar_categories',
209   `last_level_billed` int  NOT NULL DEFAULT 0 COMMENT '0=none, 1=ins1, 2=ins2, etc',
210   `last_level_closed` int  NOT NULL DEFAULT 0 COMMENT '0=none, 1=ins1, 2=ins2, etc',
211   `last_stmt_date`    date DEFAULT NULL,
212   `stmt_count`        int  NOT NULL DEFAULT 0,
213   `provider_id` INT(11) DEFAULT '0' COMMENT 'default and main provider for this visit',
214   `supervisor_id` INT(11) DEFAULT '0' COMMENT 'supervising provider, if any, for this visit',
215   `invoice_refno` varchar(31) NOT NULL DEFAULT '',
216   `referral_source` varchar(31) NOT NULL DEFAULT '',
217   `billing_facility` INT(11) NOT NULL DEFAULT 0,
218   `external_id` VARCHAR(20) DEFAULT NULL,
219   `pos_code` tinyint(4) default NULL,
220   `counselors` VARCHAR (255),
221   `appt_id` INT(11) default NULL,
222   PRIMARY KEY  (`id`),
223   KEY `pid_encounter` (`group_id`, `encounter`),
224   KEY `encounter_date` (`date`)
225 ) ENGINE=InnoDB AUTO_INCREMENT=1 ;
226 #EndIf
228 #IfMissingColumn forms therapy_group_id
229 ALTER TABLE  `forms` ADD  `therapy_group_id` INT(11) DEFAULT NULL;
230 #EndIf
232 #IfMissingColumn registry patient_encounter
233 ALTER TABLE `registry` ADD `patient_encounter` TINYINT NOT NULL DEFAULT '1';
234 #EndIf
236 #IfMissingColumn registry therapy_group_encounter
237 ALTER TABLE `registry` ADD `therapy_group_encounter` TINYINT NOT NULL DEFAULT '0';
238 #EndIf
241 #IfNotRow2D list_options list_id lists option_id attendstat
242 INSERT INTO list_options (`list_id`, `option_id`, `title`, `seq`, `is_default`, `option_value`) VALUES ('lists', 'attendstat', 'Group Attendance Statuses', '15', '0', '0');
243 INSERT INTO list_options (`list_id`, `option_id`, `title`, `seq`, `is_default`, `option_value`, `notes`, `toggle_setting_1`) VALUES ('attendstat', '-', '- Not Reported', '10', '0', '0', 'FEFDCF|0', '0');
244 INSERT INTO list_options (`list_id`, `option_id`, `title`, `seq`, `is_default`, `option_value`, `notes`, `toggle_setting_1`) VALUES ('attendstat', '@', '@ Attended', '20', '0', '0', 'FF2414|0', '1');
245 INSERT INTO list_options (`list_id`, `option_id`, `title`, `seq`, `is_default`, `option_value`, `notes`, `toggle_setting_1`) VALUES ('attendstat', '?', '? Did Not Attend', '30', '0', '0', 'BFBFBF|0', '1');
246 INSERT INTO list_options (`list_id`, `option_id`, `title`, `seq`, `is_default`, `option_value`, `notes`, `toggle_setting_1`) VALUES ('attendstat', '~', '~ Late Arrival', '40', '0', '0', 'BFBFBF|0', '1');
247 INSERT INTO list_options (`list_id`, `option_id`, `title`, `seq`, `is_default`, `option_value`, `notes`, `toggle_setting_1`) VALUES ('attendstat', 'x', 'x Cancelled', '50', '0', '0', 'FEFDCF|0', '0');
248 #EndIf
250 #IfNotRow registry directory group_attendance
251 INSERT INTO registry (name, state, directory, sql_run, unpackaged, date, priority, category, nickname, patient_encounter, therapy_group_encounter) VALUES ('Group Attendance Form', 1, 'group_attendance', 1, 1, '2015-10-15 00:00:00', 0, 'Clinical', '',0,1);
252 #EndIf
254 #IfNotRow registry directory newGroupEncounter
255 INSERT INTO registry (name, state, directory, sql_run, unpackaged, date, priority, category, nickname, patient_encounter, therapy_group_encounter) VALUES ('New Group Encounter Form', 1, 'newGroupEncounter', 1, 1, '2015-10-15 00:00:00', 0, 'Clinical', '',0,1);
256 #EndIf
258 #IfTable form_therapy_groups_attendance
259 RENAME TABLE form_therapy_groups_attendance TO form_group_attendance;
260 #EndIf
262 #IfNotTable form_group_attendance
263 CREATE TABLE `form_group_attendance` (
264   id    bigint(20) auto_increment,
265   date  date,
266   group_id      int(11),
267   user  varchar(255),
268   groupname     varchar(255),
269   authorized    tinyint(4),
270   encounter_id  int(11),
271   activity      tinyint(4),
272   PRIMARY KEY (`id`)
273 ) ENGINE=InnoDB ;
274 #EndIf
276 #IfNotRow2D list_options list_id lists option_id files_white_list
277 INSERT INTO list_options (`list_id`, `option_id`, `title`) VALUES ('lists', 'files_white_list', 'Files type white list');
278 #EndIf
280 #IfNotTable onsite_documents
281 CREATE TABLE `onsite_documents` (
282   `id` int(10) UNSIGNED NOT NULL AUTO_INCREMENT,
283   `pid` int(10) UNSIGNED DEFAULT NULL,
284   `facility` int(10) UNSIGNED DEFAULT NULL,
285   `provider` int(10) UNSIGNED DEFAULT NULL,
286   `encounter` int(10) UNSIGNED DEFAULT NULL,
287   `create_date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
288   `doc_type` varchar(255) NOT NULL,
289   `patient_signed_status` smallint(5) UNSIGNED NOT NULL,
290   `patient_signed_time` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
291   `authorize_signed_time` datetime DEFAULT NULL,
292   `accept_signed_status` smallint(5) NOT NULL,
293   `authorizing_signator` varchar(50) NOT NULL,
294   `review_date` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
295   `denial_reason` varchar(255) NOT NULL,
296   `authorized_signature` text,
297   `patient_signature` text,
298   `full_document` blob,
299   `file_name` varchar(255) NOT NULL,
300   `file_path` varchar(255) NOT NULL,
301   PRIMARY KEY (`id`)
302 ) ENGINE=InnoDB AUTO_INCREMENT=1 ;
303 #EndIf
305 #IfNotTable onsite_mail
306 CREATE TABLE `onsite_mail` (
307   `id` bigint(20) NOT NULL AUTO_INCREMENT,
308   `date` datetime DEFAULT NULL,
309   `owner` bigint(20) DEFAULT NULL,
310   `user` varchar(255) DEFAULT NULL,
311   `groupname` varchar(255) DEFAULT NULL,
312   `activity` tinyint(4) DEFAULT NULL,
313   `authorized` tinyint(4) DEFAULT NULL,
314   `header` varchar(255) DEFAULT NULL,
315   `title` varchar(255) DEFAULT NULL,
316   `body` longtext,
317   `recipient_id` varchar(128) DEFAULT NULL,
318   `recipient_name` varchar(255) DEFAULT NULL,
319   `sender_id` varchar(128) DEFAULT NULL,
320   `sender_name` varchar(255) DEFAULT NULL,
321   `assigned_to` varchar(255) DEFAULT NULL,
322   `deleted` tinyint(4) DEFAULT '0' COMMENT 'flag indicates note is deleted',
323   `delete_date` datetime DEFAULT NULL,
324   `mtype` varchar(128) DEFAULT NULL,
325   `message_status` varchar(20) NOT NULL DEFAULT 'New',
326   `mail_chain` int(11) DEFAULT NULL,
327   `reply_mail_chain` int(11) DEFAULT NULL,
328   `is_msg_encrypted` tinyint(2) DEFAULT '0' COMMENT 'Whether messsage encrypted 0-Not encrypted, 1-Encrypted',
329   PRIMARY KEY (`id`),
330   KEY `pid` (`owner`)
331 ) ENGINE=InnoDB AUTO_INCREMENT=1 ;
332 #EndIf
334 #IfNotTable onsite_messages
335 CREATE TABLE `onsite_messages` (
336   `id` int(11) NOT NULL AUTO_INCREMENT,
337   `username` varchar(64) NOT NULL,
338   `message` longtext,
339   `ip` varchar(15) NOT NULL,
340   `date` datetime NOT NULL,
341   `sender_id` int(11) UNSIGNED NOT NULL DEFAULT '0' COMMENT 'who sent id',
342  `recip_id` varchar(255) NOT NULL COMMENT 'who to id array',
343   PRIMARY KEY (`id`)
344 ) ENGINE=InnoDB COMMENT='Portal messages' AUTO_INCREMENT=1 ;
345 #EndIf
347 #IfNotTable onsite_online
348 CREATE TABLE `onsite_online` (
349   `hash` varchar(32) NOT NULL,
350   `ip` varchar(15) NOT NULL,
351   `last_update` datetime NOT NULL,
352   `username` varchar(64) NOT NULL,
353   `userid` int(11) UNSIGNED DEFAULT NULL,
354   PRIMARY KEY (`hash`)
355 ) ENGINE=InnoDB;
356 #EndIf
358 #IfNotTable onsite_portal_activity
359 CREATE TABLE `onsite_portal_activity` (
360   `id` bigint(20) NOT NULL AUTO_INCREMENT,
361   `date` datetime DEFAULT NULL,
362   `patient_id` bigint(20) DEFAULT NULL,
363   `activity` varchar(255) DEFAULT NULL,
364   `require_audit` tinyint(1) DEFAULT '1',
365   `pending_action` varchar(255) DEFAULT NULL,
366   `action_taken` varchar(255) DEFAULT NULL,
367   `status` varchar(255) DEFAULT NULL,
368   `narrative` longtext,
369   `table_action` longtext,
370   `table_args` longtext,
371   `action_user` int(11) DEFAULT NULL,
372   `action_taken_time` datetime DEFAULT NULL,
373   `checksum` longtext,
374   PRIMARY KEY (`id`),
375   KEY `date` (`date`)
376 ) ENGINE=InnoDB AUTO_INCREMENT=1 ;
377 #EndIf
379 #IfNotTable onsite_signatures
380 CREATE TABLE `onsite_signatures` (
381   `id` bigint(20) NOT NULL AUTO_INCREMENT,
382   `status` varchar(128) NOT NULL DEFAULT 'waiting',
383   `type` varchar(128) NOT NULL,
384   `created` int(11) NOT NULL,
385   `lastmod` datetime NOT NULL,
386   `pid` bigint(20) DEFAULT NULL,
387   `encounter` int(11) DEFAULT NULL,
388   `user` varchar(255) DEFAULT NULL,
389   `activity` tinyint(4) NOT NULL DEFAULT '0',
390   `authorized` tinyint(4) DEFAULT NULL,
391   `signator` varchar(255) NOT NULL,
392   `sig_image` text,
393   `signature` text,
394   `sig_hash` varchar(128) NOT NULL,
395   `ip` varchar(46) NOT NULL,
396   PRIMARY KEY (`id`),
397   UNIQUE KEY `pid` (`pid`,`user`),
398   KEY `encounter` (`encounter`)
399 ) ENGINE=InnoDB AUTO_INCREMENT=1 ;
400 #EndIf
402 #IfNotRow categories name Onsite Portal
403 INSERT INTO categories select (select MAX(id) from categories) + 1, 'Onsite Portal', '', 1, rght, rght + 5 from categories where name = 'Categories';
404 INSERT INTO categories select (select MAX(id) from categories) + 1, 'Patient', '', (select id from categories where name = 'Onsite Portal'), rght + 1, rght + 2 from categories where name = 'Categories';
405 INSERT INTO categories select (select MAX(id) from categories) + 1, 'Reviewed', '', (select id from categories where name = 'Onsite Portal'), rght + 3, rght + 4 from categories where name = 'Categories';
406 UPDATE categories SET rght = rght + 6 WHERE name = 'Categories';
407 UPDATE categories_seq SET id = (select MAX(id) from categories);
408 #EndIf
410 #IfNotRow2D list_options list_id apptstat option_id ^
411 INSERT INTO list_options ( `list_id`, `option_id`, `title`, `seq`, `is_default`, `notes` ) VALUES ('apptstat','^','^ Pending',70,0,'FEFDCF|0');
412 #EndIf
414 #IfMissingColumn registry aco_spec
415 ALTER TABLE `registry` ADD `aco_spec` varchar(63) NOT NULL default 'encounters|notes';
416 UPDATE `registry` SET `aco_spec` = 'patients|appt'     WHERE directory = 'newpatient';
417 UPDATE `registry` SET `aco_spec` = 'patients|appt'     WHERE directory = 'newGroupEncounter';
418 UPDATE `registry` SET `aco_spec` = 'encounters|coding' WHERE directory = 'fee_sheet';
419 UPDATE `registry` SET `aco_spec` = 'encounters|coding' WHERE directory = 'misc_billing_options';
420 UPDATE `registry` SET `aco_spec` = 'patients|lab'      WHERE directory = 'procedure_order';
421 #EndIf
423 #IfNotColumnType lbf_data field_value longtext
424 ALTER TABLE `lbf_data` CHANGE `field_value` `field_value` longtext;
425 #EndIf
427 #IfMissingColumn issue_types aco_spec
428 ALTER TABLE `issue_types` ADD `aco_spec` varchar(63) NOT NULL default 'patients|med';
429 #EndIf
431 #IfMissingColumn categories aco_spec
432 ALTER TABLE `categories` ADD `aco_spec` varchar(63) NOT NULL default 'patients|docs';
433 #EndIf
435 #IfNotRow background_services name ccdaservice
436 INSERT INTO `background_services` (`name`, `title`, `execute_interval`, `function`, `require_once`, `sort_order`) VALUES ('ccdaservice', 'C-CDA Node Service', 1, 'runCheck', '/ccdaservice/ssmanager.php', 95);
437 ALTER TABLE `background_services` CHANGE `running` `running` TINYINT(1) NOT NULL DEFAULT '-1' COMMENT 'True indicates managed service is busy. Skip this interval.';
438 #EndIf
440 #IfNotColumnType onsite_mail owner varchar(128)
441 ALTER TABLE `onsite_mail` CHANGE `owner` `owner` varchar(128) DEFAULT NULL;
442 #Endif
444 #IfNotColumnType openemr_postcalendar_events pc_facility int(11)
445 ALTER TABLE `openemr_postcalendar_events` CHANGE `pc_facility` `pc_facility` int(11) NOT NULL DEFAULT '0' COMMENT 'facility id for this event';
446 #Endif
448 #IfMissingColumn form_misc_billing_options onset_date
449 ALTER TABLE `form_misc_billing_options` ADD `onset_date` date default NULL;
450 UPDATE `list_options` SET `option_id` = 'DK', `title` = 'Ordering Provider' WHERE `list_id` = 'provider_qualifier_code' AND `option_id` = 'dk';
451 UPDATE `list_options` SET `option_id` = 'DN', `title` = 'Referring Provider', `is_default` = '1' WHERE `list_id` = 'provider_qualifier_code' AND `option_id` = 'dn';
452 #EndIF
454 #IfNotRow2D list_options list_id provider_qualifier_code option_id DQ
455 INSERT INTO `list_options` (`list_id`, `option_id`, `title`, `seq`, `is_default`) VALUES ('provider_qualifier_code', 'DQ', 'Supervising Provider', '30', '0');
456 #EndIf
458 #IfMissingColumn users main_menu_role
459 ALTER TABLE `users` ADD `main_menu_role` VARCHAR(50) NOT NULL DEFAULT 'standard';
460 #EndIf
462 #IfMissingColumn openemr_postcalendar_categories aco_spec
463 ALTER TABLE `openemr_postcalendar_categories` ADD COLUMN `aco_spec` VARCHAR(63) NOT NULL DEFAULT 'encounters|notes';
464 #EndIf
465 #IfNotRow2D list_options list_id lists option_id apps
466 INSERT INTO list_options (list_id,option_id,title) VALUES ('lists','apps','Apps');
467 INSERT INTO list_options (list_id,option_id,title,seq,is_default,activity) VALUES ('apps','*OpenEMR','main/main_screen.php',10,1,0);
468 INSERT INTO list_options (list_id,option_id,title,seq,is_default,activity) VALUES ('apps','Calendar','main/calendar/index.php',20,0,0);
469 #EndIf
471 #IfNotColumnType list_options list_id varchar(100)
472 ALTER TABLE `list_options` CHANGE `list_id` `list_id` VARCHAR(100) NOT NULL DEFAULT '';
473 #EndIf
475 #IfNotColumnType list_options option_id varchar(100)
476 ALTER TABLE `list_options` CHANGE `option_id` `option_id` VARCHAR(100) NOT NULL DEFAULT '';
477 #EndIf
479 #IfNotColumnType layout_options list_id varchar(100)
480 ALTER TABLE `layout_options` CHANGE `list_id` `list_id` VARCHAR(100) NOT NULL DEFAULT '';
481 #EndIf
483 #IfNotColumnType layout_options list_backup_id varchar(100)
484 ALTER TABLE `layout_options` CHANGE `list_backup_id` `list_backup_id` VARCHAR(100) NOT NULL DEFAULT '';
485 #EndIf
487 #IfNotTable patient_birthday_alert
488 CREATE TABLE `patient_birthday_alert` (
489   `pid` bigint(20) NOT NULL DEFAULT 0,
490   `user_id` bigint(20) NOT NULL DEFAULT 0,
491   `turned_off_on` date NOT NULL,
492   PRIMARY KEY  (`pid`,`user_id`)
493 ) ENGINE=InnoDB;
494 #EndIf
496 #IfNotRow4D supported_external_dataloads load_type ICD10 load_source CMS load_release_date 2017-10-01 load_filename 2018-ICD-10-PCS-Order-File.zip
497 INSERT INTO `supported_external_dataloads` (`load_type`, `load_source`, `load_release_date`, `load_filename`, `load_checksum`) VALUES
498 ('ICD10', 'CMS', '2017-10-01', '2018-ICD-10-PCS-Order-File.zip', '264b342310236f2b3927062d2c72cfe3');
499 #EndIf
501 #IfNotRow4D supported_external_dataloads load_type ICD10 load_source CMS load_release_date 2017-10-01 load_filename 2018-ICD-10-CM-General-Equivalence-Mappings.zip
502 INSERT INTO `supported_external_dataloads` (`load_type`, `load_source`, `load_release_date`, `load_filename`, `load_checksum`) VALUES
503 ('ICD10', 'CMS', '2017-10-01', '2018-ICD-10-CM-General-Equivalence-Mappings.zip', '787a025fdcf6e1da1a85be779004f670');
504 #EndIf
506 UPDATE `supported_external_dataloads` SET `load_filename`='2018-ICD-10-Code-Descriptions.zip' WHERE `load_filename`='2018-ICD-10-Code-Dedcriptions.zip' AND `load_release_date`='2017-10-01';
507 #IfNotRow4D supported_external_dataloads load_type ICD10 load_source CMS load_release_date 2017-10-01 load_filename 2018-ICD-10-Code-Descriptions.zip
508 INSERT INTO `supported_external_dataloads` (`load_type`, `load_source`, `load_release_date`, `load_filename`, `load_checksum`) VALUES
509 ('ICD10', 'CMS', '2017-10-01', '2018-ICD-10-Code-Descriptions.zip', '6f9c77440132e30f565222ca9bb6599c');
510 #EndIf
512 #IfNotRow4D supported_external_dataloads load_type ICD10 load_source CMS load_release_date 2017-10-01 load_filename 2018-ICD-10-PCS-General-Equivalence-Mappings.zip
513 INSERT INTO `supported_external_dataloads` (`load_type`, `load_source`, `load_release_date`, `load_filename`, `load_checksum`) VALUES
514 ('ICD10', 'CMS', '2017-10-01', '2018-ICD-10-PCS-General-Equivalence-Mappings.zip', 'bb73c80e272da28712887d7979b1cebf');
515 #EndIf
517 #IfColumn x12_partners x12_version
518 ALTER TABLE `x12_partners` DROP COLUMN `x12_version`;
519 #EndIf
521 #IfNotRow2D list_options list_id page_validation option_id add_edit_event#theform_prov
522 INSERT INTO `list_options` (`list_id`, `option_id`, `title`, `seq`, `notes`, `activity`) VALUES
523 ('page_validation', 'add_edit_event#theform_prov', '/interface/main/calendar/add_edit_event.php?prov=true', 170, '{}', 1);
524 #EndIf
526 #IfMissingColumn claims submitted_claim
527 ALTER TABLE `claims` ADD COLUMN `submitted_claim` TEXT COMMENT 'This claims form claim data';
528 #EndIf
530 #IfMissingColumn billing revenue_code
531 ALTER TABLE `billing` ADD COLUMN `revenue_code` varchar(6) NOT NULL DEFAULT "" COMMENT 'Item revenue code';
532 #EndIf
534 #IfMissingColumn codes revenue_code
535 ALTER TABLE `codes` ADD COLUMN `revenue_code` varchar(6) NOT NULL DEFAULT "" COMMENT 'Item revenue code';
536 #EndIf
538 #IfMissingColumn users weno_prov_id
539 ALTER TABLE `users` ADD `weno_prov_id` VARCHAR(15) DEFAULT NULL;
540 #EndIf
542 #IfMissingColumn prescriptions ntx
543 ALTER TABLE `prescriptions` ADD `ntx` INT(2) DEFAULT NULL;
544 #EndIf
546 #IfMissingColumn prescriptions rtx
547 ALTER TABLE `prescriptions` ADD `rtx` INT(2) DEFAULT NULL;
548 #EndIf
550 #IfMissingColumn prescriptions txDate
551 ALTER TABLE `prescriptions` ADD `txDate` DATE NOT NULL;
552 #EndIf
554 #IfMissingColumn pharmacies ncpdp
555 ALTER TABLE `pharmacies` ADD `ncpdp` INT(12) DEFAULT NULL;
556 #EndIf
558 #IfMissingColumn pharmacies npi
559 ALTER TABLE `pharmacies` ADD `npi` INT(12) DEFAULT NULL;
560 #EndIf
562 #IfNotRow2Dx2 list_options list_id state option_id PR title Puerto Rico
563 INSERT INTO list_options ( list_id, option_id, title, seq, is_default ) VALUES ('state','PR','Puerto Rico',39,0);
564 #EndIf
566 #IfNotTable erx_drug_paid
567 CREATE TABLE `erx_drug_paid` (
568   `drugid` int(11) NOT NULL AUTO_INCREMENT,
569   `drug_label_name` varchar(45) NOT NULL,
570   `ahfs_descr` varchar(45) NOT NULL,
571   `ndc` bigint(12) NOT NULL,
572   `price_per_unit` decimal(5,2) NOT NULL,
573   `avg_price` decimal(6,2) NOT NULL,
574   `avg_price_paid` int(6) NOT NULL,
575   `avg_savings` decimal(6,2) NOT NULL,
576   `avg_percent` decimal(6,2) NOT NULL,
577    PRIMARY KEY (`drugid`)
578    ) ENGINE=InnoDB;
579 #EndIf
581 #IfNotTable erx_rx_log
582 CREATE TABLE `erx_rx_log` (
583  `id` int(20) NOT NULL AUTO_INCREMENT,
584  `prescription_id` int(6) NOT NULL,
585  `date` varchar(25) NOT NULL,
586  `time` varchar(15) NOT NULL,
587  `code` int(6) NOT NULL,
588  `status` text,
589  `message_id` varchar(100) DEFAULT NULL,
590  `read` int(1) DEFAULT NULL,
591  PRIMARY KEY (`id`)
592   ) ENGINE=InnoDB;
593 #EndIf
595 #IfNotTable erx_narcotics
596 CREATE TABLE `erx_narcotics` (
597   `id` int(11) NOT NULL AUTO_INCREMENT,
598   `drug` varchar(255) NOT NULL,
599   `dea_number` varchar(5) NOT NULL,
600   `csa_sch` varchar(2) NOT NULL,
601   `narc` varchar(2) NOT NULL,
602   `other_names` varchar(255) NOT NULL,
603    PRIMARY KEY (`id`)
604   ) ENGINE=InnoDB;
605 #EndIf
607 UPDATE `globals` SET `gl_value`='style_red.css' WHERE `gl_name`='css_header' AND `gl_value`='style_flat_red.css';
608 UPDATE `globals` SET `gl_value`='style_manila.css' WHERE `gl_name`='css_header' AND `gl_value`='style_tan.css';
609 UPDATE `globals` SET `gl_value`='style_light.css' WHERE `gl_name`='css_header' AND (`gl_value`='style_babyblu.css'
610  OR `gl_value`='style_metal.css'
611  OR `gl_value`='style_oemr.css'
612  OR `gl_value`='style_purple.css'
613  OR `gl_value`='style_radiant.css'
614  OR `gl_value`='style_sky_blue.css');
616 UPDATE `user_settings` SET `setting_value`='style_red.css' WHERE `setting_label`='global:css_header' AND `setting_value`='style_flat_red.css';
617 UPDATE `user_settings` SET `setting_value`='style_manila.css' WHERE `setting_label`='global:css_header' AND `setting_value`='style_tan.css';
618 UPDATE `user_settings` SET `setting_value`='style_light.css' WHERE `setting_label`='global:css_header' AND (`setting_value`='style_babyblu.css'
619  OR `setting_value`='style_metal.css'
620  OR `setting_value`='style_oemr.css'
621  OR `setting_value`='style_purple.css'
622  OR `setting_value`='style_radiant.css'
623  OR `setting_value`='style_sky_blue.css');
625 #IfNotColumnType facility country_code varchar(30)
626 ALTER TABLE `facility` CHANGE `country_code` `country_code` varchar(30) NOT NULL default '';
627 #EndIf
629 #IfNotColumnType layout_options group_name varchar(255)
630 ALTER TABLE `layout_options` CHANGE `group_name` `group_name` varchar(255) NOT NULL default '';
631 #EndIf
633 #IfMissingColumn forms issue_id
634 ALTER TABLE `forms` ADD COLUMN `issue_id` bigint(20) NOT NULL default 0 COMMENT 'references lists.id to identify a case';
635 #EndIf
637 #IfMissingColumn forms provider_id
638 ALTER TABLE `forms` ADD COLUMN `provider_id` bigint(20) NOT NULL default 0 COMMENT 'references users.id to identify a provider';
639 #EndIf
641 #IfNotTable layout_group_properties
642 CREATE TABLE `layout_group_properties` (
643   grp_form_id     varchar(31)    not null,
644   grp_group_id    varchar(31)    not null default '' comment 'empty when representing the whole form',
645   grp_title       varchar(63)    not null default '' comment 'descriptive name of the form or group',
646   grp_subtitle    varchar(63)    not null default '' comment 'for display under the title',
647   grp_mapping     varchar(31)    not null default '' comment 'the form category',
648   grp_seq         int(11)        not null default 0  comment 'optional order within mapping',
649   grp_activity    tinyint(1)     not null default 1,
650   grp_repeats     int(11)        not null default 0,
651   grp_columns     int(11)        not null default 0,
652   grp_size        int(11)        not null default 0,
653   grp_issue_type  varchar(75)    not null default '',
654   grp_aco_spec    varchar(63)    not null default '',
655   grp_services    varchar(4095)  not null default '',
656   grp_products    varchar(4095)  not null default '',
657   grp_diags       varchar(4095)  not null default '',
658   PRIMARY KEY (grp_form_id, grp_group_id)
659 ) ENGINE=InnoDB;
660 ALTER TABLE layout_options ADD COLUMN group_id VARCHAR(31) NOT NULL default '' AFTER group_name;
661 #ConvertLayoutProperties
662 ALTER TABLE layout_options DROP COLUMN group_name;
663 DELETE FROM list_options WHERE list_id = 'lbfnames';
664 DELETE FROM list_options WHERE list_id = 'lists' AND option_id = 'lbfnames';
665 DELETE FROM list_options WHERE list_id = 'transactions';
666 DELETE FROM list_options WHERE list_id = 'lists' AND option_id = 'transactions';
667 #EndIf
669 #IfMissingColumn openemr_postcalendar_categories pc_constant_id
670 ALTER TABLE `openemr_postcalendar_categories` ADD `pc_constant_id` VARCHAR (255) default NULL;
671 UPDATE `openemr_postcalendar_categories` SET pc_constant_id = LOWER(REPLACE (pc_catname,' ', '_'));
672 #EndIf
674 #IfMissingColumn facility facility_taxonomy
675 ALTER TABLE facility ADD facility_taxonomy VARCHAR(15) DEFAULT NULL;
676 #EndIf