\n"; if ($oldversion < 111) { // Language upgrades from version 110 to 111 since the language names did change $oldnewlanguages=array('german_informal'=>'german-informal', 'cns'=>'cn-Hans', 'cnt'=>'cn-Hant', 'pt_br'=>'pt-BR', 'gr'=>'el', 'jp'=>'ja', 'si'=>'sl', 'se'=>'sv', 'vn'=>'vi'); foreach ($oldnewlanguages as $oldlang=>$newlang) { modify_database("","update `prefix_answers` set `language`='$newlang' where language='$oldlang'"); echo $modifyoutput; flush(); modify_database("","update `prefix_questions` set `language`='$newlang' where language='$oldlang'");echo $modifyoutput;flush(); modify_database("","update `prefix_groups` set `language`='$newlang' where language='$oldlang'");echo $modifyoutput;flush(); modify_database("","update `prefix_labels` set `language`='$newlang' where language='$oldlang'");echo $modifyoutput;flush(); modify_database("","update `prefix_surveys` set `language`='$newlang' where language='$oldlang'");echo $modifyoutput;flush(); modify_database("","update `prefix_surveys_languagesettings` set `surveyls_language`='$newlang' where surveyls_language='$oldlang'");echo $modifyoutput;flush(); modify_database("","update `prefix_users` set `lang`='$newlang' where lang='$oldlang'");echo $modifyoutput;flush(); } $resultdata=db_execute_assoc("select * from ".db_table_name("labelsets")); while ($datarow = $resultdata->FetchRow()){ $toreplace=$datarow['languages']; $toreplace=str_replace('german_informal','german-informal',$toreplace); $toreplace=str_replace('cns','cn-Hans',$toreplace); $toreplace=str_replace('cnt','cn-Hant',$toreplace); $toreplace=str_replace('pt_br','pt-BR',$toreplace); $toreplace=str_replace('gr','el',$toreplace); $toreplace=str_replace('jp','ja',$toreplace); $toreplace=str_replace('si','sl',$toreplace); $toreplace=str_replace('se','sv',$toreplace); $toreplace=str_replace('vn','vi',$toreplace); modify_database("","update `prefix_labelsets` set `languages`='$toreplace' where lid=".$datarow['lid']);echo $modifyoutput;flush(); } $resultdata=db_execute_assoc("select * from ".db_table_name("surveys")); while ($datarow = $resultdata->FetchRow()){ $toreplace=$datarow['additional_languages']; $toreplace=str_replace('german_informal','german-informal',$toreplace); $toreplace=str_replace('cns','cn-Hans',$toreplace); $toreplace=str_replace('cnt','cn-Hant',$toreplace); $toreplace=str_replace('pt_br','pt-BR',$toreplace); $toreplace=str_replace('gr','el',$toreplace); $toreplace=str_replace('jp','ja',$toreplace); $toreplace=str_replace('si','sl',$toreplace); $toreplace=str_replace('se','sv',$toreplace); $toreplace=str_replace('vn','vi',$toreplace); modify_database("","update `prefix_surveys` set `additional_languages`='$toreplace' where sid=".$datarow['sid']);echo $modifyoutput;flush(); } modify_database("","update `prefix_settings_global` set `stg_value`='111' where stg_name='DBVersion'"); echo $modifyoutput; flush(); } if ($oldversion < 112) { //The size of the users_name field is now 64 char (20 char before version 112) modify_database("","ALTER TABLE `prefix_users` CHANGE `users_name` `users_name` VARCHAR( 64 ) NOT NULL"); echo $modifyoutput; flush(); modify_database("","update `prefix_settings_global` set `stg_value`='112' where stg_name='DBVersion'"); echo $modifyoutput; flush(); } if ($oldversion < 113) { //Fixes the collation for the complete DB, tables and columns echo "Attention:The following upgrades will update your MySQL Database collations. This may take some time.
If for any reason you should get a timeout just re-run the upgrade procedure. The updating will continue where it left off.

"; flush(); fix_mysql_collation(); modify_database("","ALTER DATABASE `$databasename` DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;");echo $modifyoutput; flush(); modify_database("","update `prefix_settings_global` set `stg_value`='113' where stg_name='DBVersion'"); echo $modifyoutput; flush(); } if ($oldversion < 114) { modify_database("","ALTER TABLE `prefix_saved_control` CHANGE `email` `email` VARCHAR(320) NOT NULL"); echo $modifyoutput; flush(); modify_database("","ALTER TABLE `prefix_surveys` CHANGE `adminemail` `adminemail` VARCHAR(320) NOT NULL"); echo $modifyoutput; flush(); modify_database("","ALTER TABLE `prefix_users` CHANGE `email` `email` VARCHAR(320) NOT NULL"); echo $modifyoutput; flush(); modify_database("",'INSERT INTO `prefix_settings_global` VALUES (\'SessionName\', \'$sessionname\');');echo $modifyoutput; flush(); modify_database("","update `prefix_settings_global` set `stg_value`='114' where stg_name='DBVersion'"); echo $modifyoutput; flush(); } if ($oldversion < 126) { //Adds new "public" field modify_database("","ALTER TABLE `prefix_surveys` ADD `printanswers` CHAR(1) default 'N' AFTER allowsave"); echo $modifyoutput; flush(); modify_database("","ALTER TABLE `prefix_surveys` ADD `listpublic` CHAR(1) default 'N' AFTER `datecreated`"); echo $modifyoutput; flush(); upgrade_survey_tables117(); upgrade_survey_tables118(); // 119 modify_database("","CREATE TABLE `prefix_quota` ( `id` int(11) NOT NULL auto_increment, `sid` int(11) default NULL, `name` varchar(255) collate utf8_unicode_ci default NULL, `qlimit` int(8) default NULL, `action` int(2) default NULL, `active` int(1) NOT NULL default '1', PRIMARY KEY (`id`) ) TYPE=$databasetabletype CHARACTER SET utf8 COLLATE utf8_unicode_ci;"); echo $modifyoutput; flush(); modify_database("","CREATE TABLE `prefix_quota_members` ( `id` int(11) NOT NULL auto_increment, `sid` int(11) default NULL, `qid` int(11) default NULL, `quota_id` int(11) default NULL, `code` varchar(5) collate utf8_unicode_ci default NULL, PRIMARY KEY (`id`), UNIQUE KEY `sid` (`sid`,`qid`,`quota_id`,`code`) ) TYPE=$databasetabletype CHARACTER SET utf8 COLLATE utf8_unicode_ci;"); echo $modifyoutput; flush(); // Rename Norwegian language code from NO to NB $oldnewlanguages=array('no'=>'nb'); foreach ($oldnewlanguages as $oldlang=>$newlang) { modify_database("","update `prefix_answers` set `language`='$newlang' where language='$oldlang'");echo $modifyoutput;flush(); modify_database("","update `prefix_questions` set `language`='$newlang' where language='$oldlang'");echo $modifyoutput;flush(); modify_database("","update `prefix_groups` set `language`='$newlang' where language='$oldlang'");echo $modifyoutput;flush(); modify_database("","update `prefix_labels` set `language`='$newlang' where language='$oldlang'");echo $modifyoutput;flush(); modify_database("","update `prefix_surveys` set `language`='$newlang' where language='$oldlang'");echo $modifyoutput;flush(); modify_database("","update `prefix_surveys_languagesettings` set `surveyls_language`='$newlang' where surveyls_language='$oldlang'");echo $modifyoutput;flush(); modify_database("","update `prefix_users` set `lang`='$newlang' where lang='$oldlang'");echo $modifyoutput;flush(); } $resultdata=db_execute_assoc("select * from ".db_table_name("labelsets")); while ($datarow = $resultdata->FetchRow()){ $toreplace=$datarow['languages']; $toreplace2=str_replace('no','nb',$toreplace); if ($toreplace2!=$toreplace) {modify_database("","update `prefix_labelsets` set `languages`='$toreplace' where lid=".$datarow['lid']);echo $modifyoutput;flush();} } $resultdata=db_execute_assoc("select * from ".db_table_name("surveys")); while ($datarow = $resultdata->FetchRow()){ $toreplace=$datarow['additional_languages']; $toreplace2=str_replace('no','nb',$toreplace); if ($toreplace2!=$toreplace) {modify_database("","update `prefix_surveys` set `additional_languages`='$toreplace' where sid=".$datarow['sid']);echo $modifyoutput;flush();} } modify_database("","ALTER TABLE `prefix_surveys` ADD `htmlemail` CHAR(1) default 'N'"); echo $modifyoutput; flush(); modify_database("","ALTER TABLE `prefix_surveys` ADD `tokenanswerspersistence` CHAR(1) default 'N'"); echo $modifyoutput; flush(); modify_database("","ALTER TABLE `prefix_surveys` ADD `usecaptcha` CHAR(1) default 'N'"); echo $modifyoutput; flush(); modify_database("","ALTER TABLE `prefix_users` ADD `htmleditormode` CHAR(7) default 'default'"); echo $modifyoutput; flush(); //122 modify_database("","CREATE TABLE `prefix_templates_rights` ( `uid` int(11) NOT NULL, `folder` varchar(255) NOT NULL, `use` int(1) NOT NULL, PRIMARY KEY (`uid`,`folder`) ) TYPE=$databasetabletype CHARACTER SET utf8 COLLATE utf8_unicode_ci;"); echo $modifyoutput; flush(); modify_database("","CREATE TABLE `prefix_templates` ( `folder` varchar(255) NOT NULL, `creator` int(11) NOT NULL, PRIMARY KEY (`folder`) ) TYPE=$databasetabletype CHARACTER SET utf8 COLLATE utf8_unicode_ci;"); echo $modifyoutput; flush(); //123 modify_database("","ALTER TABLE `prefix_conditions` CHANGE `value` `value` VARCHAR(255) NOT NULL default ''"); echo $modifyoutput; flush(); modify_database("","ALTER TABLE `prefix_labels` CHANGE `title` `title` text"); echo $modifyoutput; flush(); //124 modify_database("","ALTER TABLE `prefix_surveys` ADD `bounce_email` text"); echo $modifyoutput; flush(); //125 upgrade_token_tables125(); modify_database("","ALTER TABLE `prefix_users` ADD `superadmin` tinyint(1) NOT NULL default '0'"); echo $modifyoutput; flush(); modify_database("","UPDATE `prefix_users` SET `superadmin`=1 where (create_survey=1 AND create_user=1 AND move_user=1 AND delete_user=1 AND configurator=1)"); echo $modifyoutput; flush(); modify_database("","ALTER TABLE `prefix_users` DROP COLUMN `move_user`"); echo $modifyoutput; flush(); //126 modify_database("","ALTER TABLE `prefix_questions` ADD `lid1` integer NOT NULL default '0'"); echo $modifyoutput; flush(); modify_database("","UPDATE `prefix_conditions` SET `method`='==' where (`method` is null) or `method`=''"); echo $modifyoutput; flush(); modify_database("","update `prefix_settings_global` set `stg_value`='126' where stg_name='DBVersion'"); echo $modifyoutput; flush(); } return true; } function upgrade_survey_tables117() { global $modifyoutput; $surveyidquery = "SELECT sid FROM ".db_table_name('surveys')." WHERE active='Y' and datestamp='Y'"; $surveyidresult = db_execute_num($surveyidquery); if (!$surveyidresult) {return "Database Error";} else { while ( $sv = $surveyidresult->FetchRow() ) { modify_database("","ALTER TABLE ".db_table_name('survey_'.$sv[0])." ADD `startdate` datetime AFTER `datestamp`"); echo $modifyoutput; flush(); } } } function upgrade_survey_tables118() { global $modifyoutput,$dbprefix; $surveyidquery = "SHOW TABLES LIKE '".$dbprefix."tokens%'"; $surveyidresult = db_execute_num($surveyidquery); if (!$surveyidresult) {return "Database Error";} else { while ( $sv = $surveyidresult->FetchRow() ) { modify_database("","ALTER TABLE ".$sv[0]." CHANGE `token` `token` VARCHAR(15)"); echo $modifyoutput; flush(); } } } function upgrade_token_tables125() { global $modifyoutput,$dbprefix; $surveyidquery = "SHOW TABLES LIKE '".$dbprefix."tokens%'"; $surveyidresult = db_execute_num($surveyidquery); if (!$surveyidresult) {return "Database Error";} else { while ( $sv = $surveyidresult->FetchRow() ) { modify_database("","ALTER TABLE ".$sv[0]." ADD `emailstatus` varchar(255) NOT NULL DEFAULT 'OK'"); echo $modifyoutput; flush(); } } } function fix_mysql_collation() { global $connect, $modifyoutput, $dbprefix; $sql = 'SHOW TABLE STATUS'; $result = db_execute_assoc($sql); if (!$result) { $modifyoutput .= 'SHOW TABLE - SQL Error'; } while ( $tables = $result->FetchRow() ) { // Loop through all tables in this database $table = $tables['Name']; $tablecollation=$tables['Collation']; if (strpos($table,'old_')===false && ($dbprefix=='' || ($dbprefix!='' && strpos($table,$dbprefix)!==false))) { if ($tablecollation!='utf8_unicode_ci') { modify_database("","ALTER TABLE $table COLLATE utf8_unicode_ci"); echo $modifyoutput; flush(); } # Now loop through all the fields within this table $result2 = db_execute_assoc("SHOW FULL COLUMNS FROM ".$table); while ( $column = $result2->FetchRow()) { if ($column['Collation']!= 'utf8_unicode_ci' ) { $field_name = $column['Field']; $field_type = $column['Type']; $field_default = $column['Default']; if ($field_default!='NULL') {$field_default="'".$field_default."'";} # Change text based fields $skipped_field_types = array('char', 'text', 'enum', 'set'); foreach ( $skipped_field_types as $type ) { if ( strpos($field_type, $type) !== false ) { $modstatement="ALTER TABLE $table CHANGE `$field_name` `$field_name` $field_type CHARACTER SET utf8 COLLATE utf8_unicode_ci"; if ($type!='text') {$modstatement.=" DEFAULT $field_default";} modify_database("",$modstatement); echo $modifyoutput; flush(); } } } } } } } ?>