$tag_id) { array_push( $datas, array( 'id' => $tag_id, 'name' => $tag_name, 'url_name' => str2url($tag_name), ) ); } if (!empty($datas)) { mass_inserts( PREFIX_TABLE.'tags', array_keys($datas[0]), $datas ); } $datas = array(); foreach ($tag_images as $tag_id => $images) { foreach (array_unique($images) as $image_id) { array_push( $datas, array( 'tag_id' => $tag_id, 'image_id' => $image_id, ) ); } } if (!empty($datas)) { mass_inserts( PREFIX_TABLE.'image_tag', array_keys($datas[0]), $datas ); } // // Delete images.keywords // $query = ' ALTER TABLE '.PREFIX_TABLE.'images DROP COLUMN keywords ;'; pwg_query($query); // // Add useful indexes // $query = ' ALTER TABLE '.PREFIX_TABLE.'tags ADD INDEX tags_i1(url_name) ;'; pwg_query($query); $query = ' ALTER TABLE '.PREFIX_TABLE.'image_tag ADD INDEX image_tag_i1(tag_id) ;'; pwg_query($query); // print_time('tags have replaced keywords'); } tag_replace_keywords(); $queries = array( " CREATE TABLE ".PREFIX_TABLE."search ( id int UNSIGNED NOT NULL AUTO_INCREMENT, last_seen date DEFAULT NULL, rules text, PRIMARY KEY (id) );", " CREATE TABLE ".PREFIX_TABLE."user_mail_notification ( user_id smallint(5) NOT NULL default '0', check_key varchar(16) binary NOT NULL default '', enabled enum('true','false') NOT NULL default 'false', last_send datetime default NULL, PRIMARY KEY (user_id), UNIQUE KEY uidx_check_key (check_key) );", " CREATE TABLE ".PREFIX_TABLE."upgrade ( id varchar(20) NOT NULL default '', applied datetime NOT NULL default '0000-00-00 00:00:00', description varchar(255) default NULL, PRIMARY KEY (`id`) );", " ALTER TABLE ".PREFIX_TABLE."config MODIFY COLUMN value TEXT ;", " ALTER TABLE ".PREFIX_TABLE."images ADD COLUMN has_high enum('true') default NULL ;", " ALTER TABLE ".PREFIX_TABLE."rate ADD COLUMN anonymous_id varchar(45) NOT NULL default '' ;", " ALTER TABLE ".PREFIX_TABLE."rate ADD COLUMN date date NOT NULL default '0000-00-00' ;", " ALTER TABLE ".PREFIX_TABLE."rate DROP PRIMARY KEY ;", " ALTER TABLE ".PREFIX_TABLE."rate ADD PRIMARY KEY (element_id,user_id,anonymous_id) ;", " UPDATE ".PREFIX_TABLE."rate SET date = CURDATE() ;", " DELETE FROM ".PREFIX_TABLE."sessions ;", " ALTER TABLE ".PREFIX_TABLE."sessions DROP COLUMN user_id ;", " ALTER TABLE ".PREFIX_TABLE."sessions ADD COLUMN data text NOT NULL ;", " ALTER TABLE ".PREFIX_TABLE."user_cache ADD COLUMN nb_total_images mediumint(8) unsigned default NULL ;", " ALTER TABLE ".PREFIX_TABLE."user_infos CHANGE COLUMN status status enum('webmaster','admin','normal','generic','guest') NOT NULL default 'guest' ;", " UPDATE ".PREFIX_TABLE."user_infos SET status = 'normal' WHERE status = 'guest' ;", " UPDATE ".PREFIX_TABLE."user_infos SET status = 'guest' WHERE user_id = ".$conf['guest_id']." ;", " UPDATE ".PREFIX_TABLE."user_infos SET status = 'webmaster' WHERE user_id = ".$conf['webmaster_id']." ;", " ALTER TABLE ".PREFIX_TABLE."user_infos CHANGE COLUMN template template varchar(255) NOT NULL default 'yoga/clear' ;", " UPDATE ".PREFIX_TABLE."user_infos SET template = 'yoga/dark' WHERE template = 'yoga-dark' ;", " UPDATE ".PREFIX_TABLE."user_infos SET template = 'yoga/clear' WHERE template != 'yoga/dark' ;", " ALTER TABLE ".PREFIX_TABLE."user_infos ADD COLUMN adviser enum('true','false') NOT NULL default 'false' ;", " ALTER TABLE ".PREFIX_TABLE."user_infos ADD COLUMN enabled_high enum('true','false') NOT NULL default 'true' ;", " ALTER TABLE ".PREFIX_TABLE."categories CHANGE COLUMN rank rank SMALLINT(5) UNSIGNED DEFAULT NULL ;", // configuration table " UPDATE ".PREFIX_TABLE."config SET value = 'yoga/clear' WHERE param = 'default_template' ;" ); foreach ($queries as $query) { pwg_query($query); } // // Move rate, rate_anonymous and gallery_url from config file to database // $params = array( 'gallery_url' => array( 'http://demo.phpwebgallery.net', 'URL given in RSS feed' ), 'rate' => array( 'true', 'Rating pictures feature is enabled' ), 'rate_anonymous' => array( 'true', 'Rating pictures feature is also enabled for visitors' ) ); // Get real values from config file $conf_save = $conf; unset($conf); @include(PHPWG_ROOT_PATH. 'include/config_local.inc.php'); if ( isset($conf['gallery_url']) ) { $params['gallery_url'][0] = $conf['gallery_url']; } if ( isset($conf['rate']) and is_bool($conf['rate']) ) { $params['rate'][0] = $conf['rate'] ? 'true' : 'false'; } if ( isset($conf['rate_anonymous']) and is_bool($conf['rate_anonymous']) ) { $params['rate_anonymous'][0] = $conf['rate_anonymous'] ? 'true' : 'false'; } $conf = $conf_save; // Do I already have them in DB ? $query = 'SELECT param FROM '.PREFIX_TABLE.'config'; $result = pwg_query($query); while ($row = mysql_fetch_array($result)) { unset( $params[ $row['param'] ] ); } // Perform the insert query foreach ($params as $param_key => $param_values) { $query = ' INSERT INTO '.PREFIX_TABLE.'config (param,value,comment) VALUES ('."'$param_key','$param_values[0]','$param_values[1]') ;"; pwg_query($query); } $query = " ALTER TABLE ".PREFIX_TABLE."config MODIFY COLUMN `value` TEXT;"; pwg_query($query); // // replace gallery_description by page_banner // $query = ' SELECT value FROM '.PREFIX_TABLE.'config WHERE param=\'gallery_title\' ;'; list($t) = array_from_query($query, 'value'); $query = ' SELECT value FROM '.PREFIX_TABLE.'config WHERE param=\'gallery_description\' ;'; list($d) = array_from_query($query, 'value'); $page_banner='
'.$d.'
'; $page_banner=addslashes($page_banner); $query = ' INSERT INTO '.PREFIX_TABLE.'config (param,value,comment) VALUES ( \'page_banner\', \''.$page_banner.'\', \'html displayed on the top each page of your gallery\' ) ;'; pwg_query($query); $query = ' DELETE FROM '.PREFIX_TABLE.'config WHERE param=\'gallery_description\' ;'; pwg_query($query); // // configuration for notification by mail // $query = " INSERT INTO ".CONFIG_TABLE." (param,value,comment) VALUES ( 'nbm_send_mail_as', '', 'Send mail as param value for notification by mail' ), ( 'nbm_send_detailed_content', 'true', 'Send detailed content for notification by mail' ), ( 'nbm_complementary_mail_content', '', 'Complementary mail content for notification by mail' ) ;"; pwg_query($query); // depending on the way the 1.5.0 was installed (from scratch or by upgrade) // the database structure has small differences that should be corrected. $query = ' ALTER TABLE '.PREFIX_TABLE.'users CHANGE COLUMN password password varchar(32) default NULL ;'; pwg_query($query); $to_keep = array('id', 'username', 'password', 'mail_address'); $query = ' DESC '.PREFIX_TABLE.'users ;'; $result = pwg_query($query); while ($row = mysql_fetch_array($result)) { if (!in_array($row['Field'], $to_keep)) { $query = ' ALTER TABLE '.PREFIX_TABLE.'users DROP COLUMN '.$row['Field'].' ;'; pwg_query($query); } } $query = ' ALTER TABLE '.PREFIX_TABLE.'users ADD auto_login_key varchar(64) NOT NULL ;'; pwg_query($query); ?>