moparscape.org-smf/upgrade_2-0_mysql.sql

3167 lines
105 KiB
SQL

/* ATTENTION: You don't need to run or use this file! The upgrade.php script does everything for you! */
/******************************************************************************/
--- Changing column names.
/******************************************************************************/
---# Renaming table columns.
---{
// The array holding all the changes.
$nameChanges = array(
'admin_info_files' => array(
'ID_FILE' => 'ID_FILE id_file tinyint(4) unsigned NOT NULL auto_increment',
),
'approval_queue' => array(
'ID_MSG' => 'ID_MSG id_msg int(10) unsigned NOT NULL default \'0\'',
'ID_ATTACH' => 'ID_ATTACH id_attach int(10) unsigned NOT NULL default \'0\'',
'ID_EVENT' => 'ID_EVENT id_event smallint(5) unsigned NOT NULL default \'0\'',
'attachmentType' => 'attachmentType attachment_type tinyint(3) unsigned NOT NULL default \'0\'',
),
'attachments' => array(
'ID_ATTACH' => 'ID_ATTACH id_attach int(10) unsigned NOT NULL auto_increment',
'ID_THUMB' => 'ID_THUMB id_thumb int(10) unsigned NOT NULL default \'0\'',
'ID_MSG' => 'ID_MSG id_msg int(10) unsigned NOT NULL default \'0\'',
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
'attachmentType' => 'attachmentType attachment_type tinyint(3) unsigned NOT NULL default \'0\'',
),
'ban_groups' => array(
'ID_BAN_GROUP' => 'ID_BAN_GROUP id_ban_group mediumint(8) unsigned NOT NULL auto_increment',
),
'ban_items' => array(
'ID_BAN' => 'ID_BAN id_ban mediumint(8) unsigned NOT NULL auto_increment',
'ID_BAN_GROUP' => 'ID_BAN_GROUP id_ban_group smallint(5) unsigned NOT NULL default \'0\'',
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
),
'board_permissions' => array(
'ID_GROUP' => 'ID_GROUP id_group smallint(5) NOT NULL default \'0\'',
'ID_PROFILE' => 'ID_PROFILE id_profile smallint(5) NOT NULL default \'0\'',
'addDeny' => 'addDeny add_deny tinyint(4) NOT NULL default \'1\'',
),
'boards' => array(
'ID_BOARD' => 'ID_BOARD id_board smallint(5) unsigned NOT NULL auto_increment',
'ID_CAT' => 'ID_CAT id_cat tinyint(4) unsigned NOT NULL default \'0\'',
'childLevel' => 'childLevel child_level tinyint(4) unsigned NOT NULL default \'0\'',
'ID_PARENT' => 'ID_PARENT id_parent smallint(5) unsigned NOT NULL default \'0\'',
'boardOrder' => 'boardOrder board_order smallint(5) NOT NULL default \'0\'',
'ID_LAST_MSG' => 'ID_LAST_MSG id_last_msg int(10) unsigned NOT NULL default \'0\'',
'ID_MSG_UPDATED' => 'ID_MSG_UPDATED id_msg_updated int(10) unsigned NOT NULL default \'0\'',
'memberGroups' => 'memberGroups member_groups varchar(255) NOT NULL default \'-1,0\'',
'ID_PROFILE' => 'ID_PROFILE id_profile smallint(5) unsigned NOT NULL default \'1\'',
'numTopics' => 'numTopics num_topics mediumint(8) unsigned NOT NULL default \'0\'',
'numPosts' => 'numPosts num_posts mediumint(8) unsigned NOT NULL default \'0\'',
'countPosts' => 'countPosts count_posts tinyint(4) NOT NULL default \'0\'',
'ID_THEME' => 'ID_THEME id_theme tinyint(4) unsigned NOT NULL default \'0\'',
'unapprovedPosts' => 'unapprovedPosts unapproved_posts smallint(5) NOT NULL default \'0\'',
'unapprovedTopics' => 'unapprovedTopics unapproved_topics smallint(5) NOT NULL default \'0\'',
),
'calendar' => array(
'ID_EVENT' => 'ID_EVENT id_event smallint(5) unsigned NOT NULL auto_increment',
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
'ID_BOARD' => 'ID_BOARD id_board smallint(5) unsigned NOT NULL default \'0\'',
'ID_TOPIC' => 'ID_TOPIC id_topic mediumint(8) unsigned NOT NULL default \'0\'',
'startDate' => 'startDate start_date date NOT NULL default \'0001-01-01\'',
'endDate' => 'endDate end_date date NOT NULL default \'0001-01-01\'',
),
'calendar_holidays' => array(
'ID_HOLIDAY' => 'ID_HOLIDAY id_holiday smallint(5) unsigned NOT NULL auto_increment',
'eventDate' => 'eventDate event_date date NOT NULL default \'0001-01-01\'',
),
'categories' => array(
'ID_CAT' => 'ID_CAT id_cat tinyint(4) unsigned NOT NULL auto_increment',
'catOrder' => 'catOrder cat_order tinyint(4) NOT NULL default \'0\'',
'canCollapse' => 'canCollapse can_collapse tinyint(1) NOT NULL default \'1\'',
),
'collapsed_categories' => array(
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
'ID_CAT' => 'ID_CAT id_cat tinyint(4) unsigned NOT NULL',
),
'custom_fields' => array(
'ID_FIELD' => 'ID_FIELD id_field smallint(5) NOT NULL auto_increment',
'colName' => 'colName col_name varchar(12) NOT NULL default \'\'',
'fieldName' => 'fieldName field_name varchar(40) NOT NULL default \'\'',
'fieldDesc' => 'fieldDesc field_desc varchar(255) NOT NULL default \'\'',
'fieldType' => 'fieldType field_type varchar(8) NOT NULL default \'text\'',
'fieldLength' => 'fieldLength field_length smallint(5) NOT NULL default \'255\'',
'fieldOptions' => 'fieldOptions field_options text NOT NULL',
'showReg' => 'showReg show_reg tinyint(3) NOT NULL default \'0\'',
'showDisplay' => 'showDisplay show_display tinyint(3) NOT NULL default \'0\'',
'showProfile' => 'showProfile show_profile varchar(20) NOT NULL default \'forumprofile\'',
'defaultValue' => 'defaultValue default_value varchar(8) NOT NULL default \'0\'',
),
'group_moderators' => array(
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
'ID_GROUP' => 'ID_GROUP id_group smallint(5) unsigned NOT NULL default \'0\'',
),
'log_actions' => array(
'ID_ACTION' => 'ID_ACTION id_action int(10) unsigned NOT NULL auto_increment',
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
'logTime' => 'logTime log_time int(10) unsigned NOT NULL default \'0\'',
'ID_MSG' => 'ID_MSG id_msg int(10) unsigned NOT NULL default \'0\'',
'ID_TOPIC' => 'ID_TOPIC id_topic mediumint(8) unsigned NOT NULL default \'0\'',
'ID_BOARD' => 'ID_BOARD id_board smallint(5) unsigned NOT NULL default \'0\'',
),
'log_activity' => array(
'mostOn' => 'mostOn most_on smallint(5) unsigned NOT NULL default \'0\'',
),
'log_banned' => array(
'ID_BAN_LOG' => 'ID_BAN_LOG id_ban_log mediumint(8) unsigned NOT NULL auto_increment',
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
'logTime' => 'logTime log_time int(10) unsigned NOT NULL default \'0\'',
),
'log_boards' => array(
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
'ID_MSG' => 'ID_MSG id_msg int(10) unsigned NOT NULL default \'0\'',
'ID_BOARD' => 'ID_BOARD id_board smallint(5) unsigned NOT NULL default \'0\'',
),
'log_digest' => array(
'ID_TOPIC' => 'ID_TOPIC id_topic mediumint(8) unsigned NOT NULL default \'0\'',
'ID_MSG' => 'ID_MSG id_msg int(10) unsigned NOT NULL default \'0\'',
),
'log_errors' => array(
'ID_ERROR' => 'ID_ERROR id_error mediumint(8) unsigned NOT NULL auto_increment',
'logTime' => 'logTime log_time int(10) unsigned NOT NULL default \'0\'',
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
'errorType' => 'errorType error_type char(15) NOT NULL default \'general\'',
),
'log_floodcontrol' => array(
'logTime' => 'logTime log_time int(10) unsigned NOT NULL default \'0\'',
),
'log_group_requests' => array(
'ID_REQUEST' => 'ID_REQUEST id_request mediumint(8) unsigned NOT NULL auto_increment',
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
'ID_GROUP' => 'ID_GROUP id_group smallint(5) unsigned NOT NULL default \'0\'',
),
'log_karma' => array(
'ID_TARGET' => 'ID_TARGET id_target mediumint(8) unsigned NOT NULL default \'0\'',
'ID_EXECUTOR' => 'ID_EXECUTOR id_executor mediumint(8) unsigned NOT NULL default \'0\'',
'logTime' => 'logTime log_time int(10) unsigned NOT NULL default \'0\'',
),
'log_mark_read' => array(
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
'ID_MSG' => 'ID_MSG id_msg int(10) unsigned NOT NULL default \'0\'',
'ID_BOARD' => 'ID_BOARD id_board smallint(5) unsigned NOT NULL default \'0\'',
),
'log_notify' => array(
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
'ID_TOPIC' => 'ID_TOPIC id_topic mediumint(8) unsigned NOT NULL default \'0\'',
'ID_BOARD' => 'ID_BOARD id_board smallint(5) unsigned NOT NULL default \'0\'',
),
'log_packages' => array(
'ID_INSTALL' => 'ID_INSTALL id_install int(10) NOT NULL auto_increment',
'ID_MEMBER_INSTALLED' => 'ID_MEMBER_INSTALLED id_member_installed mediumint(8) NOT NULL default \'0\'',
'ID_MEMBER_REMOVED' => 'ID_MEMBER_REMOVED id_member_removed mediumint(8) NOT NULL default \'0\'',
),
'log_polls' => array(
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
'ID_CHOICE' => 'ID_CHOICE id_choice tinyint(3) unsigned NOT NULL default \'0\'',
'ID_POLL' => 'ID_POLL id_poll mediumint(8) unsigned NOT NULL default \'0\'',
),
'log_reported' => array(
'ID_REPORT' => 'ID_REPORT id_report mediumint(8) unsigned NOT NULL auto_increment',
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
'ID_MSG' => 'ID_MSG id_msg int(10) unsigned NOT NULL default \'0\'',
'ID_TOPIC' => 'ID_TOPIC id_topic mediumint(8) unsigned NOT NULL default \'0\'',
'ID_BOARD' => 'ID_BOARD id_board smallint(5) unsigned NOT NULL default \'0\'',
),
'log_reported_comments' => array(
'ID_COMMENT' => 'ID_COMMENT id_comment mediumint(8) unsigned NOT NULL auto_increment',
'ID_REPORT' => 'ID_REPORT id_report mediumint(8) NOT NULL default \'0\'',
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
),
'log_scheduled_tasks' => array(
'ID_LOG' => 'ID_LOG id_log mediumint(8) NOT NULL auto_increment',
'ID_TASK' => 'ID_TASK id_task smallint(5) NOT NULL default \'0\'',
'timeRun' => 'timeRun time_run int(10) NOT NULL default \'0\'',
'timeTaken' => 'timeTaken time_taken float NOT NULL default \'0\'',
),
'log_search_messages' => array(
'ID_SEARCH' => 'ID_SEARCH id_search tinyint(3) unsigned NOT NULL default \'0\'',
'ID_MSG' => 'ID_MSG id_msg int(10) unsigned NOT NULL default \'0\'',
),
'log_search_results' => array(
'ID_TOPIC' => 'ID_TOPIC id_topic mediumint(8) unsigned NOT NULL default \'0\'',
'ID_MSG' => 'ID_MSG id_msg int(10) unsigned NOT NULL default \'0\'',
'ID_SEARCH' => 'ID_SEARCH id_search tinyint(3) unsigned NOT NULL default \'0\'',
),
'log_search_subjects' => array(
'ID_TOPIC' => 'ID_TOPIC id_topic mediumint(8) unsigned NOT NULL default \'0\'',
),
'log_search_topics' => array(
'ID_SEARCH' => 'ID_SEARCH id_search tinyint(3) unsigned NOT NULL default \'0\'',
'ID_TOPIC' => 'ID_TOPIC id_topic mediumint(8) unsigned NOT NULL default \'0\'',
),
'log_subscribed' => array(
'ID_SUBLOG' => 'ID_SUBLOG id_sublog int(10) unsigned NOT NULL auto_increment',
'ID_SUBSCRIBE' => 'ID_SUBSCRIBE id_subscribe mediumint(8) unsigned NOT NULL default \'0\'',
'OLD_ID_GROUP' => 'OLD_ID_GROUP old_id_group smallint(5) NOT NULL default \'0\'',
'startTime' => 'startTime start_time int(10) NOT NULL default \'0\'',
'endTime' => 'endTime end_time int(10) NOT NULL default \'0\'',
),
'log_topics' => array(
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
'ID_MSG' => 'ID_MSG id_msg int(10) unsigned NOT NULL default \'0\'',
'ID_TOPIC' => 'ID_TOPIC id_topic mediumint(8) unsigned NOT NULL default \'0\'',
),
'mail_queue' => array(
'ID_MAIL' => 'ID_MAIL id_mail int(10) unsigned NOT NULL auto_increment',
),
'members' => array(
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL auto_increment',
'memberName' => 'memberName member_name varchar(80) NOT NULL default \'\'',
'dateRegistered' => 'dateRegistered date_registered int(10) unsigned NOT NULL default \'0\'',
'ID_GROUP' => 'ID_GROUP id_group smallint(5) unsigned NOT NULL default \'0\'',
'lastLogin' => 'lastLogin last_login int(10) unsigned NOT NULL default \'0\'',
'realName' => 'realName real_name varchar(255) NOT NULL default \'\'',
'instantMessages' => 'instantMessages instant_messages smallint(5) NOT NULL default \'0\'',
'unreadMessages' => 'unreadMessages unread_messages smallint(5) NOT NULL default \'0\'',
'messageLabels' => 'messageLabels message_labels text NOT NULL',
'emailAddress' => 'emailAddress email_address varchar(255) NOT NULL default \'\'',
'personalText' => 'personalText personal_text varchar(255) NOT NULL default \'\'',
'websiteTitle' => 'websiteTitle website_title varchar(255) NOT NULL default \'\'',
'websiteUrl' => 'websiteUrl website_url varchar(255) NOT NULL default \'\'',
'ICQ' => 'ICQ icq varchar(255) NOT NULL default \'\'',
'AIM' => 'AIM aim varchar(255) NOT NULL default \'\'',
'YIM' => 'YIM yim varchar(32) NOT NULL default \'\'',
'MSN' => 'MSN msn varchar(255) NOT NULL default \'\'',
'hideEmail' => 'hideEmail hide_email tinyint(4) NOT NULL default \'0\'',
'showOnline' => 'showOnline show_online tinyint(4) NOT NULL default \'1\'',
'timeFormat' => 'timeFormat time_format varchar(80) NOT NULL default \'\'',
'timeOffset' => 'timeOffset time_offset float NOT NULL default \'0\'',
'karmaBad' => 'karmaBad karma_bad smallint(5) unsigned NOT NULL default \'0\'',
'karmaGood' => 'karmaGood karma_good smallint(5) unsigned NOT NULL default \'0\'',
'notifyAnnouncements' => 'notifyAnnouncements notify_announcements tinyint(4) NOT NULL default \'1\'',
'notifyRegularity' => 'notifyRegularity notify_regularity tinyint(4) NOT NULL default \'1\'',
'notifySendBody' => 'notifySendBody notify_send_body tinyint(4) NOT NULL default \'0\'',
'notifyTypes' => 'notifyTypes notify_types tinyint(4) NOT NULL default \'2\'',
'memberIP' => 'memberIP member_ip varchar(255) NOT NULL default \'\'',
'secretQuestion' => 'secretQuestion secret_question varchar(255) NOT NULL default \'\'',
'secretAnswer' => 'secretAnswer secret_answer varchar(64) NOT NULL default \'\'',
'ID_THEME' => 'ID_THEME id_theme tinyint(4) unsigned NOT NULL default \'0\'',
'ID_MSG_LAST_VISIT' => 'ID_MSG_LAST_VISIT id_msg_last_visit int(10) unsigned NOT NULL default \'0\'',
'additionalGroups' => 'additionalGroups additional_groups varchar(255) NOT NULL default \'\'',
'smileySet' => 'smileySet smiley_set varchar(48) NOT NULL default \'\'',
'ID_POST_GROUP' => 'ID_POST_GROUP id_post_group smallint(5) unsigned NOT NULL default \'0\'',
'totalTimeLoggedIn' => 'totalTimeLoggedIn total_time_logged_in int(10) unsigned NOT NULL default \'0\'',
'passwordSalt' => 'passwordSalt password_salt varchar(255) NOT NULL default \'\'',
'ignoreBoards' => 'ignoreBoards ignore_boards text NOT NULL',
'memberIP2' => 'memberIP2 member_ip2 varchar(255) NOT NULL default \'\'',
),
'messages' => array(
'ID_MSG' => 'ID_MSG id_msg int(10) unsigned NOT NULL auto_increment',
'ID_TOPIC' => 'ID_TOPIC id_topic mediumint(8) unsigned NOT NULL default \'0\'',
'ID_BOARD' => 'ID_BOARD id_board smallint(5) unsigned NOT NULL default \'0\'',
'posterTime' => 'posterTime poster_time int(10) unsigned NOT NULL default \'0\'',
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
'ID_MSG_MODIFIED' => 'ID_MSG_MODIFIED id_msg_modified int(10) unsigned NOT NULL default \'0\'',
'posterName' => 'posterName poster_name varchar(255) NOT NULL default \'\'',
'posterEmail' => 'posterEmail poster_email varchar(255) NOT NULL default \'\'',
'posterIP' => 'posterIP poster_ip varchar(255) NOT NULL default \'\'',
'smileysEnabled' => 'smileysEnabled smileys_enabled tinyint(4) NOT NULL default \'1\'',
'modifiedTime' => 'modifiedTime modified_time int(10) unsigned NOT NULL default \'0\'',
'modifiedName' => 'modifiedName modified_name varchar(255) NOT NULL default \'\'',
),
'membergroups' => array(
'ID_GROUP' => 'ID_GROUP id_group smallint(5) unsigned NOT NULL auto_increment',
'ID_PARENT' => 'ID_PARENT id_parent smallint(5) NOT NULL default \'-2\'',
'groupName' => 'groupName group_name varchar(80) NOT NULL default \'\'',
'onlineColor' => 'onlineColor online_color varchar(20) NOT NULL default \'\'',
'minPosts' => 'minPosts min_posts mediumint(9) NOT NULL default \'-1\'',
'maxMessages' => 'maxMessages max_messages smallint(5) unsigned NOT NULL default \'0\'',
'groupType' => 'groupType group_type tinyint(3) NOT NULL default \'0\'',
),
'message_icons' => array(
'ID_ICON' => 'ID_ICON id_icon smallint(5) unsigned NOT NULL auto_increment',
'iconOrder' => 'iconOrder icon_order smallint(5) unsigned NOT NULL default \'0\'',
'ID_BOARD' => 'ID_BOARD id_board smallint(5) unsigned NOT NULL default \'0\'',
),
'moderators' => array(
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
'ID_BOARD' => 'ID_BOARD id_board smallint(5) unsigned NOT NULL default \'0\'',
),
'package_servers' => array(
'ID_SERVER' => 'ID_SERVER id_server smallint(5) unsigned NOT NULL auto_increment',
),
'personal_messages' => array(
'ID_PM' => 'ID_PM id_pm int(10) unsigned NOT NULL auto_increment',
'ID_MEMBER_FROM' => 'ID_MEMBER_FROM id_member_from mediumint(8) unsigned NOT NULL default \'0\'',
'deletedBySender' => 'deletedBySender deleted_by_sender tinyint(3) unsigned NOT NULL default \'0\'',
'fromName' => 'fromName from_name varchar(255) NOT NULL default \'\'',
),
'permission_profiles' => array(
'ID_PROFILE' => 'ID_PROFILE id_profile smallint(5) NOT NULL auto_increment',
),
'permissions' => array(
'ID_GROUP' => 'ID_GROUP id_group smallint(5) NOT NULL default \'0\'',
'addDeny' => 'addDeny add_deny tinyint(4) NOT NULL default \'1\'',
),
'pm_recipients' => array(
'ID_PM' => 'ID_PM id_pm int(10) unsigned NOT NULL default \'0\'',
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
),
'polls' => array(
'ID_POLL' => 'ID_POLL id_poll mediumint(8) unsigned NOT NULL auto_increment',
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) unsigned NOT NULL default \'0\'',
'votingLocked' => 'votingLocked voting_locked tinyint(1) NOT NULL default \'0\'',
'maxVotes' => 'maxVotes max_votes tinyint(3) unsigned NOT NULL default \'1\'',
'expireTime' => 'expireTime expire_time int(10) unsigned NOT NULL default \'0\'',
'hideResults' => 'hideResults hide_results tinyint(3) unsigned NOT NULL default \'0\'',
'changeVote' => 'changeVote change_vote tinyint(3) unsigned NOT NULL default \'0\'',
'posterName' => 'posterName poster_name varchar(255) NOT NULL default \'\'',
),
'poll_choices' => array(
'ID_CHOICE' => 'ID_CHOICE id_choice tinyint(3) unsigned NOT NULL default \'0\'',
'ID_POLL' => 'ID_POLL id_poll mediumint(8) unsigned NOT NULL default \'0\'',
),
'scheduled_tasks' => array(
'ID_TASK' => 'ID_TASK id_task smallint(5) NOT NULL auto_increment',
'nextTime' => 'nextTime next_time int(10) NOT NULL default \'0\'',
'timeRegularity' => 'timeRegularity time_regularity smallint(5) NOT NULL default \'0\'',
'timeOffset' => 'timeOffset time_offset int(10) NOT NULL default \'0\'',
'timeUnit' => 'timeUnit time_unit varchar(1) NOT NULL default \'h\'',
),
'smileys' => array(
'ID_SMILEY' => 'ID_SMILEY id_smiley smallint(5) unsigned NOT NULL auto_increment',
'smileyRow' => 'smileyRow smiley_row tinyint(4) unsigned NOT NULL default \'0\'',
'smileyOrder' => 'smileyOrder smiley_order smallint(5) unsigned NOT NULL default \'0\'',
),
'subscriptions' => array(
'ID_SUBSCRIBE' => 'ID_SUBSCRIBE id_subscribe mediumint(8) unsigned NOT NULL auto_increment',
'ID_GROUP' => 'ID_GROUP id_group smallint(5) NOT NULL default \'0\'',
'addGroups' => 'addGroups add_groups varchar(40) NOT NULL default \'\'',
'allowPartial' => 'allowPartial allow_partial tinyint(3) NOT NULL default \'0\'',
),
'themes' => array(
'ID_MEMBER' => 'ID_MEMBER id_member mediumint(8) NOT NULL default \'0\'',
'ID_THEME' => 'ID_THEME id_theme tinyint(4) unsigned NOT NULL default \'1\'',
),
'topics' => array(
'ID_TOPIC' => 'ID_TOPIC id_topic mediumint(8) unsigned NOT NULL auto_increment',
'isSticky' => 'isSticky is_sticky tinyint(4) NOT NULL default \'0\'',
'ID_BOARD' => 'ID_BOARD id_board smallint(5) unsigned NOT NULL default \'0\'',
'ID_FIRST_MSG' => 'ID_FIRST_MSG id_first_msg int(10) unsigned NOT NULL default \'0\'',
'ID_LAST_MSG' => 'ID_LAST_MSG id_last_msg int(10) unsigned NOT NULL default \'0\'',
'ID_MEMBER_STARTED' => 'ID_MEMBER_STARTED id_member_started mediumint(8) unsigned NOT NULL default \'0\'',
'ID_MEMBER_UPDATED' => 'ID_MEMBER_UPDATED id_member_updated mediumint(8) unsigned NOT NULL default \'0\'',
'ID_POLL' => 'ID_POLL id_poll mediumint(8) unsigned NOT NULL default \'0\'',
'numReplies' => 'numReplies num_replies int(10) unsigned NOT NULL default \'0\'',
'numViews' => 'numViews num_views int(10) unsigned NOT NULL default \'0\'',
'unapprovedPosts' => 'unapprovedPosts unapproved_posts smallint(5) NOT NULL default \'0\'',
),
);
$_GET['ren_col'] = isset($_GET['ren_col']) ? (int) $_GET['ren_col'] : 0;
$step_progress['name'] = 'Renaming columns';
$step_progress['current'] = $_GET['ren_col'];
$step_progress['total'] = count($nameChanges);
$count = 0;
// Now do every table...
foreach ($nameChanges as $table_name => $table)
{
// Already done this?
$count++;
if ($_GET['ren_col'] > $count)
continue;
$_GET['ren_col'] = $count;
// Check the table exists!
$request = upgrade_query("
SHOW TABLES
LIKE '{$db_prefix}$table_name'");
if (mysql_num_rows($request) == 0)
{
mysql_free_result($request);
continue;
}
mysql_free_result($request);
// Check each column!
$actualChanges = array();
foreach ($table as $colname => $coldef)
{
$change = array(
'table' => $table_name,
'name' => $colname,
'type' => 'column',
'method' => 'change_remove',
'text' => 'CHANGE ' . $coldef,
);
// Check if this change may need a special edit.
checkChange($change);
if (protected_alter($change, $substep, true) == false)
$actualChanges[] = ' CHANGE COLUMN ' . $coldef;
}
// Do the query - if it needs doing.
if (!empty($actualChanges))
{
$change = array(
'table' => $table_name,
'name' => 'na',
'type' => 'table',
'method' => 'full_change',
'text' => implode(', ', $actualChanges),
);
// Here we go - hold on!
protected_alter($change, $substep);
}
// Update where we are!
$step_progress['current'] = $_GET['ren_col'];
}
// All done!
unset($_GET['ren_col']);
---}
---#
---# Converting "log_online".
DROP TABLE IF EXISTS {$db_prefix}log_online;
CREATE TABLE {$db_prefix}log_online (
session varchar(32) NOT NULL default '',
log_time int(10) NOT NULL default '0',
id_member mediumint(8) unsigned NOT NULL default '0',
id_spider smallint(5) unsigned NOT NULL default '0',
ip int(10) unsigned NOT NULL default '0',
url text NOT NULL,
PRIMARY KEY (session),
KEY log_time (log_time),
KEY id_member (id_member)
) ENGINE=MyISAM{$db_collation};
---#
/******************************************************************************/
--- Adding new board specific features.
/******************************************************************************/
---# Implementing board redirects.
ALTER TABLE {$db_prefix}boards
ADD COLUMN redirect varchar(255) NOT NULL default '';
---#
/******************************************************************************/
--- Adding search engine tracking.
/******************************************************************************/
---# Creating spider table.
CREATE TABLE IF NOT EXISTS {$db_prefix}spiders (
id_spider smallint(5) unsigned NOT NULL auto_increment,
spider_name varchar(255) NOT NULL default '',
user_agent varchar(255) NOT NULL default '',
ip_info varchar(255) NOT NULL default '',
PRIMARY KEY id_spider(id_spider)
) ENGINE=MyISAM{$db_collation};
INSERT IGNORE INTO {$db_prefix}spiders
(id_spider, spider_name, user_agent, ip_info)
VALUES
(1, 'Google', 'googlebot', ''),
(2, 'Yahoo!', 'slurp', ''),
(3, 'MSN', 'msnbot', ''),
(4, 'Google (Mobile)', 'Googlebot-Mobile', ''),
(5, 'Google (Image)', 'Googlebot-Image', ''),
(6, 'Google (AdSense)', 'Mediapartners-Google', ''),
(7, 'Google (Adwords)', 'AdsBot-Google', ''),
(8, 'Yahoo! (Mobile)', 'YahooSeeker/M1A1-R2D2', ''),
(9, 'Yahoo! (Image)', 'Yahoo-MMCrawler', ''),
(10, 'MSN (Mobile)', 'MSNBOT_Mobile', ''),
(11, 'MSN (Media)', 'msnbot-media', ''),
(12, 'Cuil', 'twiceler', ''),
(13, 'Ask', 'Teoma', ''),
(14, 'Baidu', 'Baiduspider', ''),
(15, 'Gigablast', 'Gigabot', ''),
(16, 'InternetArchive', 'ia_archiver-web.archive.org', ''),
(17, 'Alexa', 'ia_archiver', ''),
(18, 'Omgili', 'omgilibot', ''),
(19, 'EntireWeb', 'Speedy Spider', '');
---#
---# Removing a spider.
---{
upgrade_query("
DELETE FROM {$db_prefix}spiders
WHERE user_agent = 'yahoo'
AND spider_name = 'Yahoo! (Publisher)'
");
---}
---#
---# Creating spider hit tracking table.
CREATE TABLE IF NOT EXISTS {$db_prefix}log_spider_hits (
id_hit int(10) unsigned NOT NULL auto_increment,
id_spider smallint(5) unsigned NOT NULL default '0',
log_time int(10) unsigned NOT NULL default '0',
url varchar(255) NOT NULL default '',
processed tinyint(3) unsigned NOT NULL default '0',
PRIMARY KEY (id_hit),
KEY id_spider(id_spider),
KEY log_time(log_time),
KEY processed (processed)
) ENGINE=MyISAM{$db_collation};
---#
---# Making some changes to spider hit table...
ALTER TABLE {$db_prefix}log_spider_hits
ADD COLUMN id_hit int(10) unsigned NOT NULL auto_increment,
ADD PRIMARY KEY (id_hit);
---#
---# Creating spider statistic table.
CREATE TABLE IF NOT EXISTS {$db_prefix}log_spider_stats (
id_spider smallint(5) unsigned NOT NULL default '0',
page_hits smallint(5) unsigned NOT NULL default '0',
last_seen int(10) unsigned NOT NULL default '0',
stat_date date NOT NULL default '0001-01-01',
PRIMARY KEY (stat_date, id_spider)
) ENGINE=MyISAM{$db_collation};
---#
/******************************************************************************/
--- Adding new forum settings.
/******************************************************************************/
---# Resetting settings_updated.
REPLACE INTO {$db_prefix}settings
(variable, value)
VALUES
('settings_updated', '0'),
('last_mod_report_action', '0'),
('search_floodcontrol_time', '5'),
('next_task_time', UNIX_TIMESTAMP());
---#
---# Changing stats settings.
---{
$request = upgrade_query("
SELECT value
FROM {$db_prefix}themes
WHERE variable = 'show_sp1_info'");
if (mysql_num_rows($request) != 0)
{
upgrade_query("
DELETE FROM {$db_prefix}themes
WHERE variable = 'show_stats_index'");
upgrade_query("
UPDATE {$db_prefix}themes
SET variable = 'show_stats_index'
WHERE variable = 'show_sp1_info'");
}
upgrade_query("
DELETE FROM {$db_prefix}themes
WHERE variable = 'show_sp1_info'");
---}
---#
---# Enable cache if upgrading from 1.1 and lower.
---{
if (isset($modSettings['smfVersion']) && $modSettings['smfVersion'] <= '2.0 Beta 1')
{
$request = upgrade_query("
SELECT value
FROM {$db_prefix}settings
WHERE variable = 'cache_enable'");
list ($cache_enable) = $smcFunc['db_fetch_row']($request);
// No cache before 1.1.
if ($smcFunc['db_num_rows']($request) == 0)
upgrade_query("
INSERT INTO {$db_prefix}settings
(variable, value)
VALUES ('cache_enable', '1')");
elseif (empty($cache_enable))
upgrade_query("
UPDATE {$db_prefix}settings
SET value = '1'
WHERE variable = 'cache_enable'");
}
---}
---#
---# Changing visual verification setting.
---{
$request = upgrade_query("
SELECT value
FROM {$db_prefix}settings
WHERE variable = 'disable_visual_verification'");
if (mysql_num_rows($request) != 0)
{
list ($oldValue) = mysql_fetch_row($request);
if ($oldValue != 0)
{
// We have changed the medium setting from SMF 1.1.2.
if ($oldValue == 4)
$oldValue = 5;
upgrade_query("
UPDATE {$db_prefix}settings
SET variable = 'visual_verification_type', value = $oldValue
WHERE variable = 'disable_visual_verification'");
}
}
upgrade_query("
DELETE FROM {$db_prefix}settings
WHERE variable = 'disable_visual_verification'");
---}
---#
---# Changing visual verification setting, again.
---{
$request = upgrade_query("
SELECT value
FROM {$db_prefix}settings
WHERE variable = 'reg_verification'");
if (mysql_num_rows($request) == 0)
{
// Upgrade visual verification again!
if (!empty($modSettings['visual_verification_type']))
{
upgrade_query("
UPDATE {$db_prefix}settings
SET value = value - 1
WHERE variable = 'visual_verification_type'");
$modSettings['visual_verification_type']--;
}
// Never set?
elseif (!isset($modSettings['visual_verification_type']))
{
upgrade_query("
INSERT INTO {$db_prefix}settings
(variable, value)
VALUES
('visual_verification_type', '3')");
$modSettings['visual_verification_type'] = 3;
}
upgrade_query("
INSERT INTO {$db_prefix}settings
(variable, value)
VALUES
('reg_verification', '" . (!empty($modSettings['visual_verification_type']) ? 1 : 0) . "')");
}
---}
---#
---# Changing default personal text setting.
UPDATE {$db_prefix}settings
SET variable = 'default_personal_text'
WHERE variable = 'default_personalText';
DELETE FROM {$db_prefix}settings
WHERE variable = 'default_personalText';
---#
---# Removing allow hide email setting.
DELETE FROM {$db_prefix}settings
WHERE variable = 'allow_hideEmail'
OR variable = 'allow_hide_email';
---#
---# Ensuring stats index setting present...
INSERT IGNORE INTO {$db_prefix}themes
(id_theme, variable, value)
VALUES
(1, 'show_stats_index', '0');
---#
---# Ensuring forum width setting present...
INSERT IGNORE INTO {$db_prefix}themes
(id_theme, variable, value)
VALUES
(1, 'forum_width', '90%');
---#
---# Replacing old calendar settings...
---{
// Only try it if one of the "new" settings doesn't yet exist.
if (!isset($modSettings['cal_showholidays']) || !isset($modSettings['cal_showbdays']) || !isset($modSettings['cal_showevents']))
{
// Default to just the calendar setting.
$modSettings['cal_showholidays'] = empty($modSettings['cal_showholidaysoncalendar']) ? 0 : 1;
$modSettings['cal_showbdays'] = empty($modSettings['cal_showbdaysoncalendar']) ? 0 : 1;
$modSettings['cal_showevents'] = empty($modSettings['cal_showeventsoncalendar']) ? 0 : 1;
// Then take into account board index.
if (!empty($modSettings['cal_showholidaysonindex']))
$modSettings['cal_showholidays'] = $modSettings['cal_showholidays'] === 1 ? 2 : 3;
if (!empty($modSettings['cal_showbdaysonindex']))
$modSettings['cal_showbdays'] = $modSettings['cal_showbdays'] === 1 ? 2 : 3;
if (!empty($modSettings['cal_showeventsonindex']))
$modSettings['cal_showevents'] = $modSettings['cal_showevents'] === 1 ? 2 : 3;
// Actually save the settings.
upgrade_query("
INSERT IGNORE INTO {$db_prefix}settings
(variable, value)
VALUES
('cal_showholidays', $modSettings[cal_showholidays]),
('cal_showbdays', $modSettings[cal_showbdays]),
('cal_showevents', $modSettings[cal_showevents])");
}
---}
---#
---# Fixing the calendar holidays if they were somehow wrong before...
UPDATE {$db_prefix}calendar_holidays
SET event_date = '2013-11-28'
WHERE event_date = '2013-11-21'
AND title = 'Thanksgiving';
UPDATE {$db_prefix}calendar_holidays
SET event_date = '2014-11-27'
WHERE event_date = '2014-11-20'
AND title = 'Thanksgiving';
UPDATE {$db_prefix}calendar_holidays
SET event_date = '2019-11-28'
WHERE event_date = '2019-11-21'
AND title = 'Thanksgiving';
UPDATE {$db_prefix}calendar_holidays
SET event_date = '2013-09-02'
WHERE event_date = '2013-09-09'
AND title = 'Labor Day';
UPDATE {$db_prefix}calendar_holidays
SET event_date = '2014-09-01'
WHERE event_date = '2014-09-08'
AND title = 'Labor Day';
UPDATE {$db_prefix}calendar_holidays
SET event_date = '2019-09-02'
WHERE event_date = '2019-09-09'
AND title = 'Labor Day';
---#
---# Deleting old calendar settings...
DELETE FROM {$db_prefix}settings
WHERE VARIABLE IN ('cal_showholidaysonindex', 'cal_showbdaysonindex', 'cal_showeventsonindex',
'cal_showholidaysoncalendar', 'cal_showbdaysoncalendar', 'cal_showeventsoncalendar',
'cal_holidaycolor', 'cal_bdaycolor', 'cal_eventcolor');
---#
---# Adjusting calendar maximum year...
---{
if (!isset($modSettings['cal_maxyear']) || $modSettings['cal_maxyear'] == '2010')
{
upgrade_query("
REPLACE INTO {$db_prefix}settings
(variable, value)
VALUES
('cal_maxyear', '2020')");
}
---}
---#
---# Adding advanced signature settings...
---{
if (empty($modSettings['signature_settings']))
{
if (isset($modSettings['max_signatureLength']))
$modSettings['signature_settings'] = '1,' . $modSettings['max_signatureLength'] . ',0,0,0,0,0,0:';
else
$modSettings['signature_settings'] = '1,300,0,0,0,0,0,0:';
upgrade_query("
INSERT IGNORE INTO {$db_prefix}settings
(variable, value)
VALUES
('signature_settings', '$modSettings[signature_settings]')");
upgrade_query("
DELETE FROM {$db_prefix}settings
WHERE variable = 'max_signatureLength'");
}
---}
---#
---# Updating spam protection settings.
---{
if (empty($modSettings['pm_spam_settings']))
{
if (isset($modSettings['max_pm_recipients']))
$modSettings['pm_spam_settings'] = $modSettings['max_pm_recipients'] . ',5,20';
else
$modSettings['pm_spam_settings'] = '10,5,20';
}
elseif (substr_count($modSettings['pm_spam_settings'], ',') == 1)
{
$modSettings['pm_spam_settings'] .= ',20';
}
upgrade_query("
INSERT IGNORE INTO {$db_prefix}settings
(variable, value)
VALUES
('pm_spam_settings', '$modSettings[pm_spam_settings]')");
upgrade_query("
DELETE FROM {$db_prefix}settings
WHERE variable = 'max_pm_recipients'");
---}
---#
---# Adjusting timezone settings...
---{
if (!isset($modSettings['default_timezone']) && function_exists('date_default_timezone_set'))
{
$server_offset = mktime(0, 0, 0, 1, 1, 1970);
$timezone_id = 'Etc/GMT' . ($server_offset > 0 ? '+' : '') . ($server_offset / 3600);
if (date_default_timezone_set($timezone_id))
upgrade_query("
REPLACE INTO {$db_prefix}settings
(variable, value)
VALUES
('default_timezone', '$timezone_id')");
}
---}
---#
---# Checking theme layers are correct for default themes.
---{
$request = upgrade_query("
SELECT id_theme, value, variable
FROM {$db_prefix}themes
WHERE variable = 'theme_layers'
OR variable = 'theme_dir'");
$themeLayerChanges = array();
while ($row = mysql_fetch_assoc($request))
{
$themeLayerChanges[$row['id_theme']][$row['variable']] = $row['value'];
}
mysql_free_result($request);
foreach ($themeLayerChanges as $id_theme => $data)
{
// Has to be a SMF provided theme and have custom layers defined.
if (!isset($data['theme_layers']) || !isset($data['theme_dir']) || !in_array(substr($data['theme_dir'], -7), array('default', 'babylon', 'classic')))
continue;
$layers = explode(',', $data['theme_layers']);
foreach ($layers as $k => $v)
if ($v == 'main')
{
$layers[$k] = 'html,body';
upgrade_query("
UPDATE {$db_prefix}themes
SET value = '" . implode(',', $layers) . "'
WHERE id_theme = $id_theme
AND variable = 'theme_layers'");
break;
}
}
---}
---#
---# Adding index to log_notify table...
ALTER TABLE {$db_prefix}log_notify
ADD INDEX id_topic (id_topic, id_member);
---#
/******************************************************************************/
--- Adding custom profile fields.
/******************************************************************************/
---# Creating "custom_fields" table...
CREATE TABLE IF NOT EXISTS {$db_prefix}custom_fields (
id_field smallint(5) NOT NULL auto_increment,
col_name varchar(12) NOT NULL default '',
field_name varchar(40) NOT NULL default '',
field_desc varchar(255) NOT NULL default '',
field_type varchar(8) NOT NULL default 'text',
field_length smallint(5) NOT NULL default '255',
field_options text NOT NULL,
mask varchar(255) NOT NULL default '',
show_reg tinyint(3) NOT NULL default '0',
show_display tinyint(3) NOT NULL default '0',
show_profile varchar(20) NOT NULL default 'forumprofile',
private tinyint(3) NOT NULL default '0',
active tinyint(3) NOT NULL default '1',
bbc tinyint(3) NOT NULL default '0',
default_value varchar(255) NOT NULL default '',
PRIMARY KEY (id_field),
UNIQUE col_name (col_name)
) ENGINE=MyISAM{$db_collation};
---#
---# Adding search ability to custom fields.
ALTER TABLE {$db_prefix}custom_fields
ADD COLUMN can_search tinyint(3) NOT NULL default '0' AFTER bbc;
---#
---# Fixing default value field length.
ALTER TABLE {$db_prefix}custom_fields
CHANGE COLUMN default_value default_value varchar(255) NOT NULL default '';
---#
---# Enhancing privacy settings for custom fields.
---{
if (isset($modSettings['smfVersion']) && $modSettings['smfVersion'] <= '2.0 Beta 1')
{
upgrade_query("
UPDATE {$db_prefix}custom_fields
SET private = 2
WHERE private = 1");
}
if (isset($modSettings['smfVersion']) && $modSettings['smfVersion'] < '2.0 Beta 4')
{
upgrade_query("
UPDATE {$db_prefix}custom_fields
SET private = 3
WHERE private = 2");
}
---}
---#
---# Checking display fields setup correctly..
---{
if (isset($modSettings['smfVersion']) && $modSettings['smfVersion'] <= '2.0 Beta 1' && isset($modSettings['displayFields']) && @unserialize($modSettings['displayFields']) == false)
{
$request = upgrade_query("
SELECT col_name, field_name, bbc
FROM {$db_prefix}custom_fields
WHERE show_display = 1
AND active = 1
AND private != 2");
$fields = array();
while ($row = mysql_fetch_assoc($request))
{
$fields[] = array(
'c' => strtr($row['col_name'], array('|' => '', ';' => '')),
'f' => strtr($row['field_name'], array('|' => '', ';' => '')),
'b' => ($row['bbc'] ? '1' : '0')
);
}
mysql_free_result($request);
upgrade_query("
UPDATE {$db_prefix}settings
SET value = '" . mysql_real_escape_string(serialize($fields)) . "'
WHERE variable = 'displayFields'");
}
---}
---#
---# Adding new custom fields columns.
ALTER TABLE {$db_prefix}custom_fields
ADD enclose text NOT NULL;
ALTER TABLE {$db_prefix}custom_fields
ADD placement tinyint(3) NOT NULL default '0';
---#
/******************************************************************************/
--- Adding email digest functionality.
/******************************************************************************/
---# Creating "log_digest" table...
CREATE TABLE IF NOT EXISTS {$db_prefix}log_digest (
id_topic mediumint(8) unsigned NOT NULL default '0',
id_msg int(10) unsigned NOT NULL default '0',
note_type varchar(10) NOT NULL default 'post',
daily tinyint(3) unsigned NOT NULL default '0',
exclude mediumint(8) unsigned NOT NULL default '0'
) ENGINE=MyISAM{$db_collation};
---#
---# Adding digest option to "members" table...
ALTER TABLE {$db_prefix}members
CHANGE COLUMN notifyOnce notify_regularity tinyint(4) unsigned NOT NULL default '1';
---#
/******************************************************************************/
--- Making changes to the package manager.
/******************************************************************************/
---# Creating "log_packages" table...
CREATE TABLE IF NOT EXISTS {$db_prefix}log_packages (
id_install int(10) NOT NULL auto_increment,
filename varchar(255) NOT NULL default '',
package_id varchar(255) NOT NULL default '',
name varchar(255) NOT NULL default '',
version varchar(255) NOT NULL default '',
id_member_installed mediumint(8) NOT NULL default '0',
member_installed varchar(255) NOT NULL default '',
time_installed int(10) NOT NULL default '0',
id_member_removed mediumint(8) NOT NULL default '0',
member_removed varchar(255) NOT NULL default '',
time_removed int(10) NOT NULL default '0',
install_state tinyint(3) NOT NULL default '1',
failed_steps text NOT NULL,
themes_installed varchar(255) NOT NULL default '',
db_changes text NOT NULL,
PRIMARY KEY (id_install),
KEY filename (filename(15))
) ENGINE=MyISAM{$db_collation};
---#
---# Adding extra "log_packages" columns...
ALTER TABLE {$db_prefix}log_packages
ADD db_changes text NOT NULL AFTER themes_installed;
---#
---# Changing URL to SMF package server...
UPDATE {$db_prefix}package_servers
SET url = 'http://custom.simplemachines.org/packages/mods'
WHERE url = 'http://mods.simplemachines.org';
---#
/******************************************************************************/
--- Creating mail queue functionality.
/******************************************************************************/
---# Creating "mail_queue" table...
CREATE TABLE IF NOT EXISTS {$db_prefix}mail_queue (
id_mail int(10) unsigned NOT NULL auto_increment,
time_sent int(10) NOT NULL default '0',
recipient varchar(255) NOT NULL default '',
body text NOT NULL,
subject varchar(255) NOT NULL default '',
headers text NOT NULL,
send_html tinyint(3) NOT NULL default '0',
priority tinyint(3) NOT NULL default '1',
PRIMARY KEY (id_mail),
KEY time_sent (time_sent),
KEY mail_priority (priority, id_mail)
) ENGINE=MyISAM{$db_collation};
---#
---# Adding new mail queue settings...
---{
if (!isset($modSettings['mail_next_send']))
{
upgrade_query("
INSERT INTO {$db_prefix}settings
(variable, value)
VALUES
('mail_next_send', '0'),
('mail_recent', '0000000000|0')");
}
---}
---#
---# Change mail queue indexes...
ALTER TABLE {$db_prefix}mail_queue
DROP INDEX priority;
ALTER TABLE {$db_prefix}mail_queue
ADD INDEX mail_priority (priority, id_mail);
---#
---# Adding type to mail queue...
ALTER TABLE {$db_prefix}mail_queue
ADD private tinyint(1) NOT NULL default '0';
---#
/******************************************************************************/
--- Creating moderation center tables.
/******************************************************************************/
---# Creating "log_reported" table...
CREATE TABLE IF NOT EXISTS {$db_prefix}log_reported (
id_report mediumint(8) unsigned NOT NULL auto_increment,
id_msg int(10) unsigned NOT NULL default '0',
id_topic mediumint(8) unsigned NOT NULL default '0',
id_board smallint(5) unsigned NOT NULL default '0',
id_member mediumint(8) unsigned NOT NULL default '0',
membername varchar(255) NOT NULL default '',
subject varchar(255) NOT NULL default '',
body text NOT NULL,
time_started int(10) NOT NULL default '0',
time_updated int(10) NOT NULL default '0',
num_reports mediumint(6) NOT NULL default '0',
closed tinyint(3) NOT NULL default '0',
ignore_all tinyint(3) NOT NULL default '0',
PRIMARY KEY (id_report),
KEY id_member (id_member),
KEY id_topic (id_topic),
KEY closed (closed),
KEY time_started (time_started),
KEY id_msg (id_msg)
) ENGINE=MyISAM{$db_collation};
---#
---# Creating "log_reported_comments" table...
CREATE TABLE IF NOT EXISTS {$db_prefix}log_reported_comments (
id_comment mediumint(8) unsigned NOT NULL auto_increment,
id_report mediumint(8) NOT NULL default '0',
id_member mediumint(8) NOT NULL,
membername varchar(255) NOT NULL default '',
comment varchar(255) NOT NULL default '',
time_sent int(10) NOT NULL,
PRIMARY KEY (id_comment),
KEY id_report (id_report),
KEY id_member (id_member),
KEY time_sent (time_sent)
) ENGINE=MyISAM{$db_collation};
---#
---# Adding moderator center permissions...
---{
// Don't do this twice!
if (@$modSettings['smfVersion'] < '2.0')
{
// Try find people who probably should see the moderation center.
$request = upgrade_query("
SELECT id_group, add_deny, permission
FROM {$db_prefix}permissions
WHERE permission = 'calendar_edit_any'");
$inserts = array();
while ($row = mysql_fetch_assoc($request))
{
$inserts[] = "($row[id_group], 'access_mod_center', $row[add_deny])";
}
mysql_free_result($request);
if (!empty($inserts))
upgrade_query("
INSERT IGNORE INTO {$db_prefix}permissions
(id_group, permission, add_deny)
VALUES
" . implode(',', $inserts));
}
---}
---#
---# Adding moderation center preferences...
ALTER TABLE {$db_prefix}members
ADD mod_prefs varchar(20) NOT NULL default '';
---#
/******************************************************************************/
--- Adding user warnings.
/******************************************************************************/
---# Creating member notices table...
CREATE TABLE IF NOT EXISTS {$db_prefix}log_member_notices (
id_notice mediumint(8) unsigned NOT NULL auto_increment,
subject varchar(255) NOT NULL default '',
body text NOT NULL,
PRIMARY KEY (id_notice)
) ENGINE=MyISAM{$db_collation};
---#
---# Creating comments table...
CREATE TABLE IF NOT EXISTS {$db_prefix}log_comments (
id_comment mediumint(8) unsigned NOT NULL auto_increment,
id_member mediumint(8) unsigned NOT NULL default '0',
member_name varchar(80) NOT NULL default '',
comment_type varchar(8) NOT NULL default 'warning',
id_recipient mediumint(8) unsigned NOT NULL default '0',
recipient_name varchar(255) NOT NULL default '',
log_time int(10) NOT NULL default '0',
id_notice mediumint(8) unsigned NOT NULL default '0',
counter tinyint(3) NOT NULL default '0',
body text NOT NULL,
PRIMARY KEY (id_comment),
KEY id_recipient (id_recipient),
KEY log_time (log_time),
KEY comment_type (comment_type(8))
) ENGINE=MyISAM{$db_collation};
---#
---# Adding user warning column...
ALTER TABLE {$db_prefix}members
ADD warning tinyint(4) NOT NULL default '0';
ALTER TABLE {$db_prefix}members
ADD INDEX warning (warning);
---#
---# Ensuring warning settings are present...
---{
// Only do this if not already done.
if (empty($modSettings['warning_settings']))
{
upgrade_query("
INSERT IGNORE INTO {$db_prefix}settings
(variable, value)
VALUES
('warning_settings', '1,20,0'),
('warning_watch', '10'),
('warning_moderate', '35'),
('warning_mute', '60')");
}
---}
---#
/******************************************************************************/
--- Enhancing membergroups.
/******************************************************************************/
---# Creating "log_group_requests" table...
CREATE TABLE IF NOT EXISTS {$db_prefix}log_group_requests (
id_request mediumint(8) unsigned NOT NULL auto_increment,
id_member mediumint(8) unsigned NOT NULL default '0',
id_group smallint(5) unsigned NOT NULL default '0',
time_applied int(10) unsigned NOT NULL default '0',
reason text NOT NULL,
PRIMARY KEY (id_request),
UNIQUE id_member (id_member, id_group)
) ENGINE=MyISAM{$db_collation};
---#
---# Adding new membergroup table columns...
ALTER TABLE {$db_prefix}membergroups
ADD description text NOT NULL AFTER group_name;
ALTER TABLE {$db_prefix}membergroups
ADD group_type tinyint(3) NOT NULL default '0';
ALTER TABLE {$db_prefix}membergroups
ADD hidden tinyint(3) NOT NULL default '0';
---#
---# Creating "group_moderators" table...
CREATE TABLE IF NOT EXISTS {$db_prefix}group_moderators (
id_group smallint(5) unsigned NOT NULL default '0',
id_member mediumint(8) unsigned NOT NULL default '0',
PRIMARY KEY (id_group, id_member)
) ENGINE=MyISAM{$db_collation};
---#
/******************************************************************************/
--- Updating attachment data...
/******************************************************************************/
---# Altering attachment table.
ALTER TABLE {$db_prefix}attachments
ADD COLUMN fileext varchar(8) NOT NULL default '',
ADD COLUMN mime_type varchar(20) NOT NULL default '';
ALTER TABLE {$db_prefix}attachments
ADD COLUMN id_folder tinyint(3) NOT NULL default '1';
---#
---# Adding file hash.
ALTER TABLE {$db_prefix}attachments
ADD COLUMN file_hash varchar(40) NOT NULL default '';
---#
---# Populate the attachment extension.
UPDATE {$db_prefix}attachments
SET fileext = LOWER(SUBSTRING(filename, 1 - (INSTR(REVERSE(filename), '.'))))
WHERE fileext = ''
AND INSTR(filename, '.')
AND attachment_type != 3;
---#
---# Updating thumbnail attachments JPG.
UPDATE {$db_prefix}attachments
SET fileext = 'jpg'
WHERE attachment_type = 3
AND fileext = ''
AND RIGHT(filename, 9) = 'JPG_thumb';
---#
---# Updating thumbnail attachments PNG.
UPDATE {$db_prefix}attachments
SET fileext = 'png'
WHERE attachment_type = 3
AND fileext = ''
AND RIGHT(filename, 9) = 'PNG_thumb';
---#
---# Calculating attachment mime types.
---{
// Don't ever bother doing this twice.
if (@$modSettings['smfVersion'] < '2.0' || @$modSettings['smfVersion'] === '2.0 a')
{
$request = upgrade_query("
SELECT MAX(id_attach)
FROM {$db_prefix}attachments");
list ($step_progress['total']) = $smcFunc['db_fetch_row']($request);
$smcFunc['db_free_result']($request);
$_GET['a'] = isset($_GET['a']) ? (int) $_GET['a'] : 0;
$step_progress['name'] = 'Calculating MIME Types';
$step_progress['current'] = $_GET['a'];
if (!function_exists('getAttachmentFilename'))
{
function getAttachmentFilename($filename, $attachment_id)
{
global $modSettings;
$clean_name = strtr($filename, 'ŠŽšžŸÀÁÂÃÄÅÇÈÉÊËÌÍÎÏÑÒÓÔÕÖØÙÚÛÜÝàáâãäåçèéêëìíîïñòóôõöøùúûüýÿ', 'SZszYAAAAAACEEEEIIIINOOOOOOUUUUYaaaaaaceeeeiiiinoooooouuuuyy');
$clean_name = strtr($clean_name, array('Þ' => 'TH', 'þ' => 'th', 'Ð' => 'DH', 'ð' => 'dh', 'ß' => 'ss', 'Œ' => 'OE', 'œ' => 'oe', 'Æ' => 'AE', 'æ' => 'ae', 'µ' => 'u'));
$clean_name = preg_replace(array('/\s/', '/[^\w_\.\-]/'), array('_', ''), $clean_name);
$enc_name = $attachment_id . '_' . strtr($clean_name, '.', '_') . md5($clean_name);
$clean_name = preg_replace('~\.[\.]+~', '.', $clean_name);
if ($attachment_id == false)
return $clean_name;
if (file_exists($modSettings['attachmentUploadDir'] . '/' . $enc_name))
$filename = $modSettings['attachmentUploadDir'] . '/' . $enc_name;
else
$filename = $modSettings['attachmentUploadDir'] . '/' . $clean_name;
return $filename;
}
}
$ext_updates = array();
// What headers are valid results for getimagesize?
$validTypes = array(
1 => 'gif',
2 => 'jpeg',
3 => 'png',
5 => 'psd',
6 => 'bmp',
7 => 'tiff',
8 => 'tiff',
9 => 'jpeg',
14 => 'iff',
);
$is_done = false;
while (!$is_done)
{
nextSubStep($substep);
$request = upgrade_query("
SELECT id_attach, filename, fileext
FROM {$db_prefix}attachments
WHERE fileext != ''
AND mime_type = ''
LIMIT $_GET[a], 100");
// Finished?
if ($smcFunc['db_num_rows']($request) == 0)
$is_done = true;
while ($row = $smcFunc['db_fetch_assoc']($request))
{
$filename = getAttachmentFilename($row['filename'], $row['id_attach']);
if (!file_exists($filename))
continue;
// Is it an image?
$size = @getimagesize($filename);
// Nothing valid?
if (empty($size) || empty($size[0]))
continue;
// Got the mime?
elseif (!empty($size['mime']))
$mime = $size['mime'];
// Otherwise is it valid?
elseif (!isset($validTypes[$size[2]]))
continue;
else
$mime = 'image/' . $validTypes[$size[2]];
// Let's try keep updates to a minimum.
if (!isset($ext_updates[$row['fileext'] . $size['mime']]))
$ext_updates[$row['fileext'] . $size['mime']] = array(
'fileext' => $row['fileext'],
'mime' => $mime,
'files' => array(),
);
$ext_updates[$row['fileext'] . $size['mime']]['files'][] = $row['id_attach'];
}
$smcFunc['db_free_result']($request);
// Do the updates?
foreach ($ext_updates as $key => $update)
{
upgrade_query("
UPDATE {$db_prefix}attachments
SET mime_type = '$update[mime]'
WHERE id_attach IN (" . implode(',', $update['files']) . ")");
// Remove it.
unset($ext_updates[$key]);
}
$_GET['a'] += 100;
$step_progress['current'] = $_GET['a'];
}
unset($_GET['a']);
}
---}
---#
/******************************************************************************/
--- Adding Post Moderation.
/******************************************************************************/
---# Creating "approval_queue" table...
CREATE TABLE IF NOT EXISTS {$db_prefix}approval_queue (
id_msg int(10) unsigned NOT NULL default '0',
id_attach int(10) unsigned NOT NULL default '0',
id_event smallint(5) unsigned NOT NULL default '0'
) ENGINE=MyISAM{$db_collation};
---#
---# Adding approved column to attachments table...
ALTER TABLE {$db_prefix}attachments
ADD approved tinyint(3) NOT NULL default '1';
---#
---# Adding approved column to messages table...
ALTER TABLE {$db_prefix}messages
ADD approved tinyint(3) NOT NULL default '1';
ALTER TABLE {$db_prefix}messages
ADD INDEX approved (approved);
---#
---# Adding unapproved count column to topics table...
ALTER TABLE {$db_prefix}topics
ADD unapproved_posts smallint(5) NOT NULL default '0';
---#
---# Adding approved column to topics table...
ALTER TABLE {$db_prefix}topics
ADD approved tinyint(3) NOT NULL default '1',
ADD INDEX approved (approved);
---#
---# Adding approved columns to boards table...
ALTER TABLE {$db_prefix}boards
ADD unapproved_posts smallint(5) NOT NULL default '0',
ADD unapproved_topics smallint(5) NOT NULL default '0';
---#
---# Adding post moderation permissions...
---{
// We *cannot* do this twice!
if (@$modSettings['smfVersion'] < '2.0')
{
// Anyone who can currently edit posts we assume can approve them...
$request = upgrade_query("
SELECT id_group, id_board, add_deny, permission
FROM {$db_prefix}board_permissions
WHERE permission = 'modify_any'");
$inserts = array();
while ($row = mysql_fetch_assoc($request))
{
$inserts[] = "($row[id_group], $row[id_board], 'approve_posts', $row[add_deny])";
}
mysql_free_result($request);
if (!empty($inserts))
upgrade_query("
INSERT IGNORE INTO {$db_prefix}board_permissions
(id_group, id_board, permission, add_deny)
VALUES
" . implode(',', $inserts));
}
---}
---#
/******************************************************************************/
--- Upgrading the error log.
/******************************************************************************/
---# Adding columns to log_errors table...
ALTER TABLE {$db_prefix}log_errors
ADD error_type char(15) NOT NULL default 'general';
ALTER TABLE {$db_prefix}log_errors
ADD file varchar(255) NOT NULL default '',
ADD line mediumint(8) unsigned NOT NULL default '0';
---#
---# Updating error log table...
---{
$request = upgrade_query("
SELECT COUNT(*)
FROM {$db_prefix}log_errors");
list($totalActions) = mysql_fetch_row($request);
mysql_free_result($request);
$_GET['m'] = !empty($_GET['m']) ? (int) $_GET['m'] : '0';
$step_progress['total'] = $totalActions;
$step_progress['current'] = $_GET['m'];
while ($_GET['m'] < $totalActions)
{
nextSubStep($substep);
$request = upgrade_query("
SELECT id_error, message, file, line
FROM {$db_prefix}log_errors
LIMIT $_GET[m], 500");
while($row = mysql_fetch_assoc($request))
{
preg_match('~<br />(%1\$s: )?([\w\. \\\\/\-_:]+)<br />(%2\$s: )?([\d]+)~', $row['message'], $matches);
if (!empty($matches[2]) && !empty($matches[4]) && empty($row['file']) && empty($row['line']))
{
$row['file'] = addslashes(str_replace('\\', '/', $matches[2]));
$row['line'] = (int) $matches[4];
$row['message'] = addslashes(preg_replace('~<br />(%1\$s: )?([\w\. \\\\/\-_:]+)<br />(%2\$s: )?([\d]+)~', '', $row['message']));
}
else
continue;
upgrade_query("
UPDATE {$db_prefix}log_errors
SET file = SUBSTRING('$row[file]', 1, 255),
line = $row[line],
message = SUBSTRING('$row[message]', 1, 65535)
WHERE id_error = $row[id_error]
LIMIT 1");
}
$_GET['m'] += 500;
$step_progress['current'] = $_GET['m'];
}
unset($_GET['m']);
---}
---#
/******************************************************************************/
--- Adding Scheduled Tasks Data.
/******************************************************************************/
---# Creating Scheduled Task Table...
CREATE TABLE IF NOT EXISTS {$db_prefix}scheduled_tasks (
id_task smallint(5) NOT NULL auto_increment,
next_time int(10) NOT NULL default '0',
time_offset int(10) NOT NULL default '0',
time_regularity smallint(5) NOT NULL default '0',
time_unit varchar(1) NOT NULL default 'h',
disabled tinyint(3) NOT NULL default '0',
task varchar(24) NOT NULL default '',
PRIMARY KEY (id_task),
KEY next_time (next_time),
KEY disabled (disabled),
UNIQUE task (task)
) ENGINE=MyISAM{$db_collation};
---#
---# Populating Scheduled Task Table...
INSERT IGNORE INTO {$db_prefix}scheduled_tasks
(next_time, time_offset, time_regularity, time_unit, disabled, task)
VALUES
(0, 0, 2, 'h', 0, 'approval_notification'),
(0, 0, 7, 'd', 0, 'auto_optimize'),
(0, 60, 1, 'd', 0, 'daily_maintenance'),
(0, 0, 1, 'd', 0, 'daily_digest'),
(0, 0, 1, 'w', 0, 'weekly_digest'),
(0, 0, 1, 'd', 1, 'birthdayemails'),
(0, 120, 1, 'd', 0, 'paid_subscriptions');
---#
---# Adding the simple machines scheduled task.
---{
// Randomise the time.
$randomTime = 82800 + rand(0, 86399);
upgrade_query("
INSERT IGNORE INTO {$db_prefix}scheduled_tasks
(next_time, time_offset, time_regularity, time_unit, disabled, task)
VALUES
(0, {$randomTime}, 1, 'd', 0, 'fetchSMfiles')");
---}
---#
---# Deleting old scheduled task items...
DELETE FROM {$db_prefix}scheduled_tasks
WHERE task = 'clean_cache';
---#
---# Moving auto optimise settings to scheduled task...
---{
if (!isset($modSettings['next_task_time']) && isset($modSettings['autoOptLastOpt']))
{
// Try move over the regularity...
if (isset($modSettings['autoOptDatabase']))
{
$disabled = empty($modSettings['autoOptDatabase']) ? 1 : 0;
$regularity = $disabled ? 7 : $modSettings['autoOptDatabase'];
$next_time = $modSettings['autoOptLastOpt'] + 3600 * 24 * $modSettings['autoOptDatabase'];
// Update the task accordingly.
upgrade_query("
UPDATE {$db_prefix}scheduled_tasks
SET disabled = $disabled, time_regularity = $regularity, next_time = $next_time
WHERE task = 'auto_optimize'");
}
// Delete the old settings!
upgrade_query("
DELETE FROM {$db_prefix}settings
WHERE VARIABLE IN ('autoOptLastOpt', 'autoOptDatabase')");
}
---}
---#
---# Creating Scheduled Task Log Table...
CREATE TABLE IF NOT EXISTS {$db_prefix}log_scheduled_tasks (
id_log mediumint(8) NOT NULL auto_increment,
id_task smallint(5) NOT NULL default '0',
time_run int(10) NOT NULL default '0',
time_taken float NOT NULL default '0',
PRIMARY KEY (id_log)
) ENGINE=MyISAM{$db_collation};
---#
---# Adding new scheduled task setting...
---{
if (!isset($modSettings['next_task_time']))
{
upgrade_query("
INSERT INTO {$db_prefix}settings
(variable, value)
VALUES
('next_task_time', '0')");
}
---}
---#
---# Setting the birthday email template if not set...
---{
if (!isset($modSettings['birthday_email']))
{
upgrade_query("
INSERT INTO {$db_prefix}settings
(variable, value)
VALUES
('birthday_email', 'happy_birthday')");
}
---}
---#
/******************************************************************************/
--- Adding permission profiles for boards.
/******************************************************************************/
---# Creating "permission_profiles" table...
CREATE TABLE IF NOT EXISTS {$db_prefix}permission_profiles (
id_profile smallint(5) NOT NULL auto_increment,
profile_name varchar(255) NOT NULL default '',
PRIMARY KEY (id_profile)
) ENGINE=MyISAM{$db_collation};
---#
---# Adding profile columns to boards table...
ALTER TABLE {$db_prefix}boards
ADD id_profile smallint(5) unsigned NOT NULL default '1' AFTER member_groups;
---#
---# Adding profile columns to board permission table...
ALTER TABLE {$db_prefix}board_permissions
ADD id_profile smallint(5) unsigned NOT NULL default '1' AFTER id_group;
ALTER TABLE {$db_prefix}board_permissions
DROP PRIMARY KEY;
ALTER TABLE {$db_prefix}board_permissions
ADD PRIMARY KEY (id_group, id_profile, permission);
---#
---# Cleaning up some 2.0 Beta 1 permission profile bits...
---{
$request = upgrade_query("
SELECT id_profile
FROM {$db_prefix}permission_profiles
WHERE profile_name = ''");
$profiles = array();
while ($row = mysql_fetch_assoc($request))
$profiles[] = $row['id_profile'];
mysql_free_result($request);
if (!empty($profiles))
{
$request = upgrade_query("
SELECT id_profile, name
FROM {$db_prefix}boards
WHERE id_profile IN (" . implode(',', $profiles) . ")");
$done_ids = array();
while ($row = mysql_fetch_assoc($request))
{
if (isset($done_ids[$row['id_profile']]))
continue;
$done_ids[$row['id_profile']] = true;
$row['name'] = mysql_real_escape_string($row['name']);
upgrade_query("
UPDATE {$db_prefix}permission_profiles
SET profile_name = '$row[name]'
WHERE id_profile = $row[id_profile]");
}
mysql_free_result($request);
}
---}
---#
---# Migrating old board profiles to profile system
---{
// Doing this twice would be awful!
$request = upgrade_query("
SELECT COUNT(*)
FROM {$db_prefix}permission_profiles");
list ($profileCount) = mysql_fetch_row($request);
mysql_free_result($request);
if ($profileCount == 0)
{
// Everything starts off invalid.
upgrade_query("
UPDATE {$db_prefix}board_permissions
SET id_profile = 0");
// Insert a boat load of default profile permissions.
upgrade_query("
INSERT INTO {$db_prefix}permission_profiles
(id_profile, profile_name)
VALUES
(1, 'default'),
(2, 'no_polls'),
(3, 'reply_only'),
(4, 'read_only')");
// Update the default permissions, this is easy!
upgrade_query("
UPDATE {$db_prefix}board_permissions
SET id_profile = 1
WHERE id_board = 0");
// Load all the other permissions
$request = upgrade_query("
SELECT id_board, id_group, permission, add_deny
FROM {$db_prefix}board_permissions
WHERE id_profile = 0");
$all_perms = array();
while ($row = mysql_fetch_assoc($request))
$all_perms[$row['id_board']][$row['id_group']][$row['permission']] = $row['add_deny'];
mysql_free_result($request);
// Now we have the profile profiles for this installation. We now need to go through each board and work out what the permission profile should be!
$request = upgrade_query("
SELECT id_board, name, permission_mode
FROM {$db_prefix}boards");
$board_updates = array();
while ($row = mysql_fetch_assoc($request))
{
$row['name'] = addslashes($row['name']);
// Is it a truely local permission board? If so this is a new profile!
if ($row['permission_mode'] == 1)
{
// I know we could cache this, but I think we need to be practical - this is slow but guaranteed to work.
upgrade_query("
INSERT INTO {$db_prefix}permission_profiles
(profile_name)
VALUES
('$row[name]')");
$board_updates[mysql_insert_id()][] = $row['id_board'];
}
// Otherwise, dear god, this is an old school "simple" permission...
elseif ($row['permission_mode'] > 1 && $row['permission_mode'] < 5)
{
$board_updates[$row['permission_mode']][] = $row['id_board'];
}
// Otherwise this is easy. It becomes default.
else
$board_updates[1][] = $row['id_board'];
}
mysql_free_result($request);
// Update the board tables.
foreach ($board_updates as $profile => $boards)
{
if (empty($boards))
continue;
$boards = implode(',', $boards);
upgrade_query("
UPDATE {$db_prefix}boards
SET id_profile = $profile
WHERE id_board IN ($boards)");
// If it's a custom profile then update this too.
if ($profile > 4)
upgrade_query("
UPDATE {$db_prefix}board_permissions
SET id_profile = $profile
WHERE id_board IN ($boards)
AND id_profile = 0");
}
// Just in case we have any random permissions that didn't have boards.
upgrade_query("
DELETE FROM {$db_prefix}board_permissions
WHERE id_profile = 0");
}
---}
---#
---# Removing old board permissions column...
ALTER TABLE {$db_prefix}board_permissions
DROP COLUMN id_board;
---#
---# Check the predefined profiles all have the right permissions.
---{
// What are all the permissions people can have.
$mod_permissions = array(
'moderate_board', 'post_new', 'post_reply_own', 'post_reply_any', 'poll_post', 'poll_add_any',
'poll_remove_any', 'poll_view', 'poll_vote', 'poll_lock_any', 'poll_edit_any', 'report_any',
'lock_own', 'send_topic', 'mark_any_notify', 'mark_notify', 'delete_own', 'modify_own', 'make_sticky',
'lock_any', 'remove_any', 'move_any', 'merge_any', 'split_any', 'delete_any', 'modify_any', 'approve_posts',
'post_attachment', 'view_attachments', 'post_unapproved_replies_any', 'post_unapproved_replies_own',
'post_unapproved_attachments', 'post_unapproved_topics',
);
$no_poll_reg = array(
'post_new', 'post_reply_own', 'post_reply_any', 'poll_view', 'poll_vote', 'report_any',
'lock_own', 'send_topic', 'mark_any_notify', 'mark_notify', 'delete_own', 'modify_own',
'post_attachment', 'view_attachments', 'remove_own', 'post_unapproved_replies_any', 'post_unapproved_replies_own',
'post_unapproved_attachments', 'post_unapproved_topics',
);
$reply_only_reg = array(
'post_reply_own', 'post_reply_any', 'poll_view', 'poll_vote', 'report_any',
'lock_own', 'send_topic', 'mark_any_notify', 'mark_notify', 'delete_own', 'modify_own',
'post_attachment', 'view_attachments', 'remove_own', 'post_unapproved_replies_any', 'post_unapproved_replies_own',
'post_unapproved_attachments',
);
$read_only_reg = array(
'poll_view', 'poll_vote', 'report_any', 'send_topic', 'mark_any_notify', 'mark_notify', 'view_attachments',
);
// Clear all the current predefined profiles.
upgrade_query("
DELETE FROM {$db_prefix}board_permissions
WHERE id_profile IN (2,3,4)");
// Get all the membergroups - cheating to use the fact id_group = 1 exists to get a group of 0.
$request = upgrade_query("
SELECT IF(id_group = 1, 0, id_group) AS id_group
FROM {$db_prefix}membergroups
WHERE id_group != 0
AND min_posts = -1");
$inserts = array();
while ($row = mysql_fetch_assoc($request))
{
if ($row['id_group'] == 2 || $row['id_group'] == 3)
{
foreach ($mod_permissions as $permission)
{
$inserts[] = "($row[id_group], 2, '$permission')";
$inserts[] = "($row[id_group], 3, '$permission')";
$inserts[] = "($row[id_group], 4, '$permission')";
}
}
else
{
foreach ($no_poll_reg as $permission)
$inserts[] = "($row[id_group], 2, '$permission')";
foreach ($reply_only_reg as $permission)
$inserts[] = "($row[id_group], 3, '$permission')";
foreach ($read_only_reg as $permission)
$inserts[] = "($row[id_group], 4, '$permission')";
}
}
mysql_free_result($request);
upgrade_query("
INSERT INTO {$db_prefix}board_permissions
(id_group, id_profile, permission)
VALUES (-1, 2, 'poll_view'),
(-1, 3, 'poll_view'),
(-1, 4, 'poll_view'),
" . implode(', ', $inserts));
---}
---#
---# Adding inherited permissions...
ALTER TABLE {$db_prefix}membergroups
ADD id_parent smallint(5) NOT NULL default '-2';
---#
---# Make sure admins and moderators don't inherit...
UPDATE {$db_prefix}membergroups
SET id_parent = -2
WHERE id_group = 1
OR id_group = 3;
---#
---# Deleting old permission settings...
DELETE FROM {$db_prefix}settings
WHERE VARIABLE IN ('permission_enable_by_board', 'autoOptDatabase');
---#
---# Removing old permission_mode column...
ALTER TABLE {$db_prefix}boards
DROP COLUMN permission_mode;
---#
/******************************************************************************/
--- Adding Some Additional Functionality.
/******************************************************************************/
---# Adding column to hold the boards being ignored ...
ALTER TABLE {$db_prefix}members
ADD ignore_boards text NOT NULL;
---#
---# Purge flood control ...
DELETE FROM {$db_prefix}log_floodcontrol;
---#
---# Adding advanced flood control ...
ALTER TABLE {$db_prefix}log_floodcontrol
ADD log_type varchar(8) NOT NULL default 'post';
---#
---# Sorting out flood control keys ...
ALTER TABLE {$db_prefix}log_floodcontrol
DROP PRIMARY KEY,
ADD PRIMARY KEY (ip(16), log_type(8));
---#
---# Adding guest voting ...
ALTER TABLE {$db_prefix}polls
ADD guest_vote tinyint(3) NOT NULL default '0';
DELETE FROM {$db_prefix}log_polls
WHERE id_member < 0;
ALTER TABLE {$db_prefix}log_polls
DROP PRIMARY KEY;
ALTER TABLE {$db_prefix}log_polls
ADD INDEX id_poll (id_poll, id_member, id_choice);
---#
---# Implementing admin feature toggles.
---{
if (!isset($modSettings['admin_features']))
{
// Work out what they used to have enabled.
$enabled_features = array('rg');
if (!empty($modSettings['cal_enabled']))
$enabled_features[] = 'cd';
if (!empty($modSettings['karmaMode']))
$enabled_features[] = 'k';
if (!empty($modSettings['modlog_enabled']))
$enabled_features[] = 'ml';
if (!empty($modSettings['paid_enabled']))
$enabled_features[] = 'ps';
$enabled_features = implode(',', $enabled_features);
upgrade_query("
INSERT INTO {$db_prefix}settings
(variable, value)
VALUES
('admin_features', '$enabled_features')");
}
---}
---#
---# Adding advanced password brute force protection to "members" table...
ALTER TABLE {$db_prefix}members
ADD passwd_flood varchar(12) NOT NULL default '';
---#
/******************************************************************************/
--- Adding some columns to moderation log
/******************************************************************************/
---# Add the columns and the keys to log_actions ...
ALTER TABLE {$db_prefix}log_actions
ADD id_board smallint(5) unsigned NOT NULL default '0',
ADD id_topic mediumint(8) unsigned NOT NULL default '0',
ADD id_msg int(10) unsigned NOT NULL default '0',
ADD KEY id_board (id_board),
ADD KEY id_msg (id_msg);
---#
---# Add the user log...
ALTER TABLE {$db_prefix}log_actions
ADD id_log tinyint(3) unsigned NOT NULL default '1',
ADD KEY id_log (id_log);
---#
---# Update the information already in log_actions
---{
$request = upgrade_query("
SELECT COUNT(*)
FROM {$db_prefix}log_actions");
list($totalActions) = mysql_fetch_row($request);
mysql_free_result($request);
$_GET['m'] = !empty($_GET['m']) ? (int) $_GET['m'] : '0';
$step_progress['total'] = $totalActions;
$step_progress['current'] = $_GET['m'];
while ($_GET['m'] < $totalActions)
{
nextSubStep($substep);
$mrequest = upgrade_query("
SELECT id_action, extra, id_board, id_topic, id_msg
FROM {$db_prefix}log_actions
LIMIT $_GET[m], 500");
while ($row = mysql_fetch_assoc($mrequest))
{
if (!empty($row['id_board']) || !empty($row['id_topic']) || !empty($row['id_msg']))
continue;
$row['extra'] = @unserialize($row['extra']);
// Corrupt?
$row['extra'] = is_array($row['extra']) ? $row['extra'] : array();
if (!empty($row['extra']['board']))
{
$board_id = (int) $row['extra']['board'];
unset($row['extra']['board']);
}
else
$board_id = '0';
if (!empty($row['extra']['board_to']) && empty($board_id))
{
$board_id = (int) $row['extra']['board_to'];
unset($row['extra']['board_to']);
}
if (!empty($row['extra']['topic']))
{
$topic_id = (int) $row['extra']['topic'];
unset($row['extra']['topic']);
if (empty($board_id))
{
$trequest = upgrade_query("
SELECT id_board
FROM {$db_prefix}topics
WHERE id_topic=$topic_id
LIMIT 1");
if (mysql_num_rows($trequest))
list($board_id) = mysql_fetch_row($trequest);
mysql_free_result($trequest);
}
}
else
$topic_id = '0';
if(!empty($row['extra']['message']))
{
$msg_id = (int) $row['extra']['message'];
unset($row['extra']['message']);
if (empty($topic_id) || empty($board_id))
{
$trequest = upgrade_query("
SELECT id_board, id_topic
FROM {$db_prefix}messages
WHERE id_msg=$msg_id
LIMIT 1");
if (mysql_num_rows($trequest))
list($board_id, $topic_id) = mysql_fetch_row($trequest);
mysql_free_result($trequest);
}
}
else
$msg_id = '0';
$row['extra'] = addslashes(serialize($row['extra']));
upgrade_query("UPDATE {$db_prefix}log_actions SET id_board=$board_id, id_topic=$topic_id, id_msg=$msg_id, extra='$row[extra]' WHERE id_action=$row[id_action]");
}
$_GET['m'] += 500;
$step_progress['current'] = $_GET['m'];
}
unset($_GET['m']);
---}
---#
/******************************************************************************/
--- Create a repository for the javascript files from Simple Machines...
/******************************************************************************/
---# Creating repository table ...
CREATE TABLE IF NOT EXISTS {$db_prefix}admin_info_files (
id_file tinyint(4) unsigned NOT NULL auto_increment,
filename varchar(255) NOT NULL default '',
path varchar(255) NOT NULL default '',
parameters varchar(255) NOT NULL default '',
data text NOT NULL,
filetype varchar(255) NOT NULL default '',
PRIMARY KEY (id_file),
KEY filename (filename(30))
) ENGINE=MyISAM{$db_collation};
---#
---# Add in the files to get from Simple Machines...
INSERT IGNORE INTO {$db_prefix}admin_info_files
(id_file, filename, path, parameters)
VALUES
(1, 'current-version.js', '/smf/', 'version=%3$s'),
(2, 'detailed-version.js', '/smf/', 'language=%1$s&version=%3$s'),
(3, 'latest-news.js', '/smf/', 'language=%1$s&format=%2$s'),
(4, 'latest-packages.js', '/smf/', 'language=%1$s&version=%3$s'),
(5, 'latest-smileys.js', '/smf/', 'language=%1$s&version=%3$s'),
(6, 'latest-support.js', '/smf/', 'language=%1$s&version=%3$s'),
(7, 'latest-themes.js', '/smf/', 'language=%1$s&version=%3$s');
---#
---# Ensure that the table has the filetype column
ALTER TABLE {$db_prefix}admin_info_files
ADD filetype varchar(255) NOT NULL default '';
---#
---# Set the filetype for the files
UPDATE {$db_prefix}admin_info_files
SET filetype='text/javascript'
WHERE id_file IN (1,2,3,4,5,6,7);
---#
---# Ensure that the files from Simple Machines get updated
UPDATE {$db_prefix}scheduled_tasks
SET next_time = UNIX_TIMESTAMP()
WHERE id_task = 7
LIMIT 1;
---#
/******************************************************************************/
--- Adding new personal messaging functionality.
/******************************************************************************/
---# Adding personal message rules table...
CREATE TABLE IF NOT EXISTS {$db_prefix}pm_rules (
id_rule int(10) unsigned NOT NULL auto_increment,
id_member int(10) unsigned NOT NULL default '0',
rule_name varchar(60) NOT NULL,
criteria text NOT NULL,
actions text NOT NULL,
delete_pm tinyint(3) unsigned NOT NULL default '0',
is_or tinyint(3) unsigned NOT NULL default '0',
PRIMARY KEY (id_rule),
KEY id_member (id_member),
KEY delete_pm (delete_pm)
) ENGINE=MyISAM{$db_collation};
---#
---# Adding new message status columns...
ALTER TABLE {$db_prefix}members
ADD COLUMN new_pm tinyint(3) NOT NULL default '0';
ALTER TABLE {$db_prefix}members
ADD COLUMN pm_prefs mediumint(8) NOT NULL default '0';
ALTER TABLE {$db_prefix}pm_recipients
ADD COLUMN is_new tinyint(3) NOT NULL default '0';
---#
---# Set the new status to be correct....
---{
// Don't do this twice!
if (@$modSettings['smfVersion'] < '2.0')
{
// Set all unread messages as new.
upgrade_query("
UPDATE {$db_prefix}pm_recipients
SET is_new = 1
WHERE is_read = 0");
// Also set members to have a new pm if they have any unread.
upgrade_query("
UPDATE {$db_prefix}members
SET new_pm = 1
WHERE unread_messages > 0");
}
---}
---#
---# Adding personal message tracking column...
ALTER TABLE {$db_prefix}personal_messages
ADD id_pm_head int(10) unsigned default '0' NOT NULL AFTER id_pm,
ADD INDEX id_pm_head (id_pm_head);
---#
---# Adding personal message tracking column...
UPDATE {$db_prefix}personal_messages
SET id_pm_head = id_pm
WHERE id_pm_head = 0;
---#
/******************************************************************************/
--- Adding Open ID support.
/******************************************************************************/
---# Adding Open ID Assocation table...
CREATE TABLE IF NOT EXISTS {$db_prefix}openid_assoc (
server_url text NOT NULL,
handle varchar(255) NOT NULL default '',
secret text NOT NULL,
issued int(10) NOT NULL default '0',
expires int(10) NOT NULL default '0',
assoc_type varchar(64) NOT NULL,
PRIMARY KEY (server_url(125), handle(125)),
KEY expires (expires)
) ENGINE=MyISAM{$db_collation};
---#
---# Adding column to hold Open ID URL...
ALTER TABLE {$db_prefix}members
ADD openid_uri text NOT NULL;
---#
/******************************************************************************/
--- Adding paid subscriptions.
/******************************************************************************/
---# Creating subscriptions table...
CREATE TABLE IF NOT EXISTS {$db_prefix}subscriptions(
id_subscribe mediumint(8) unsigned NOT NULL auto_increment,
name varchar(60) NOT NULL default '',
description varchar(255) NOT NULL default '',
cost text NOT NULL,
length varchar(6) NOT NULL default '',
id_group smallint(5) NOT NULL default '0',
add_groups varchar(40) NOT NULL default '',
active tinyint(3) NOT NULL default '1',
repeatable tinyint(3) NOT NULL default '0',
allow_partial tinyint(3) NOT NULL default '0',
reminder tinyint(3) NOT NULL default '0',
email_complete text NOT NULL,
PRIMARY KEY (id_subscribe),
KEY active (active)
) ENGINE=MyISAM{$db_collation};
---#
---# Creating log_subscribed table...
CREATE TABLE IF NOT EXISTS {$db_prefix}log_subscribed(
id_sublog int(10) unsigned NOT NULL auto_increment,
id_subscribe mediumint(8) unsigned NOT NULL default '0',
id_member int(10) NOT NULL default '0',
old_id_group smallint(5) NOT NULL default '0',
start_time int(10) NOT NULL default '0',
end_time int(10) NOT NULL default '0',
status tinyint(3) NOT NULL default '0',
payments_pending tinyint(3) NOT NULL default '0',
pending_details text NOT NULL,
reminder_sent tinyint(3) NOT NULL default '0',
vendor_ref varchar(255) NOT NULL default '',
PRIMARY KEY (id_sublog),
UNIQUE KEY id_subscribe (id_subscribe, id_member),
KEY end_time (end_time),
KEY reminder_sent (reminder_sent),
KEY payments_pending (payments_pending),
KEY id_member (id_member)
) ENGINE=MyISAM{$db_collation};
---#
---# Clean up any pre-2.0 mod settings.
UPDATE {$db_prefix}settings
SET variable = 'paid_currency_code'
WHERE variable = 'currency_code';
UPDATE {$db_prefix}settings
SET variable = 'paid_currency_symbol'
WHERE variable = 'currency_symbol';
DELETE FROM {$db_prefix}settings
WHERE variable = 'currency_code'
OR variable = 'currency_symbol';
---#
---# Clean up any pre-2.0 mod settings (part 2).
---{
$request = upgrade_query("
SHOW COLUMNS
FROM {$db_prefix}subscriptions");
$new_cols = array('repeatable', 'reminder', 'email_complete', 'allow_partial');
$new_cols = array_flip($new_cols);
while ($request && $row = mysql_fetch_row($request))
{
$row[0] = strtolower($row[0]);
if (isset($new_cols[$row[0]]))
unset($new_cols[$row[0]]);
}
if ($request)
mysql_free_result($request);
if (isset($new_cols['repeatable']))
upgrade_query("
ALTER TABLE {$db_prefix}subscriptions
ADD COLUMN Repeatable tinyint(3) NOT NULL default '0'");
if (isset($new_cols['reminder']))
upgrade_query("
ALTER TABLE {$db_prefix}subscriptions
ADD COLUMN reminder tinyint(3) NOT NULL default '0'");
if (isset($new_cols['email_complete']))
upgrade_query("
ALTER TABLE {$db_prefix}subscriptions
ADD COLUMN email_complete text NOT NULL");
if (isset($new_cols['allowpartial']))
upgrade_query("
ALTER TABLE {$db_prefix}subscriptions
ADD COLUMN allow_partial tinyint(3) NOT NULL default '0'");
$request = upgrade_query("
SHOW COLUMNS
FROM {$db_prefix}log_subscribed");
$new_cols = array('reminder_sent', 'vendor_ref', 'payments_pending', 'pending_details');
$new_cols = array_flip($new_cols);
while ($request && $row = mysql_fetch_row($request))
{
if (isset($new_cols[$row[0]]))
unset($new_cols[$row[0]]);
}
if ($request)
mysql_free_result($request);
if (isset($new_cols['reminder_sent']))
upgrade_query("
ALTER TABLE {$db_prefix}log_subscribed
ADD COLUMN reminder_sent tinyint(3) NOT NULL default '0'");
if (isset($new_cols['vendor_ref']))
upgrade_query("
ALTER TABLE {$db_prefix}log_subscribed
ADD COLUMN vendor_ref varchar(255) NOT NULL default ''");
if (isset($new_cols['payments_pending']))
upgrade_query("
ALTER TABLE {$db_prefix}log_subscribed
ADD COLUMN payments_pending tinyint(3) NOT NULL default '0'");
if (isset($new_cols['pending_details']))
{
upgrade_query("
UPDATE {$db_prefix}log_subscribed
SET status = 0
WHERE status = 1");
upgrade_query("
UPDATE {$db_prefix}log_subscribed
SET status = 1
WHERE status = 2");
upgrade_query("
ALTER TABLE {$db_prefix}log_subscribed
ADD COLUMN pending_details text NOT NULL");
}
---}
---#
---# Confirming paid subscription keys are in place ...
ALTER TABLE {$db_prefix}log_subscribed
ADD KEY reminder_sent (reminder_sent),
ADD KEY end_time (end_time),
ADD KEY payments_pending (payments_pending),
ADD KEY status (status);
---#
/******************************************************************************/
--- Adding weekly maintenance task.
/******************************************************************************/
---# Adding scheduled task...
INSERT IGNORE INTO {$db_prefix}scheduled_tasks (next_time, time_offset, time_regularity, time_unit, disabled, task) VALUES (0, 0, 1, 'w', 0, 'weekly_maintenance');
---#
/******************************************************************************/
--- Adding log pruning.
/******************************************************************************/
---# Adding pruning option...
INSERT IGNORE INTO {$db_prefix}settings (variable, value) VALUES ('pruningOptions', '30,180,180,180,30,0');
---#
/******************************************************************************/
--- Adding restore topic from recycle.
/******************************************************************************/
---# Adding restore from recycle feature...
ALTER TABLE {$db_prefix}topics
ADD COLUMN id_previous_board smallint(5) NOT NULL default '0',
ADD COLUMN id_previous_topic mediumint(8) NOT NULL default '0';
---#
/******************************************************************************/
--- Providing more room for apf options.
/******************************************************************************/
---# Changing field_options column to a larger field type...
ALTER TABLE {$db_prefix}custom_fields
CHANGE field_options field_options text NOT NULL;
---#
/******************************************************************************/
--- Providing more room for ignoring boards.
/******************************************************************************/
---# Changing ignore_boards column to a larger field type...
ALTER TABLE {$db_prefix}members
CHANGE ignore_boards ignore_boards text NOT NULL;
---#
/******************************************************************************/
--- Allow for longer calendar event/holiday titles.
/******************************************************************************/
---# Changing event title column to a larger field type...
ALTER TABLE {$db_prefix}calendar
CHANGE title title varchar(255) NOT NULL default '';
---#
---# Changing holidays title column to a larger field type...
ALTER TABLE {$db_prefix}calendar_holidays
CHANGE title title varchar(255) NOT NULL default '';
---#
/******************************************************************************/
--- Adding extra columns to polls.
/******************************************************************************/
---# Adding reset poll timestamp and guest voters counter...
ALTER TABLE {$db_prefix}polls
ADD COLUMN reset_poll int(10) unsigned NOT NULL default '0' AFTER guest_vote,
ADD COLUMN num_guest_voters int(10) unsigned NOT NULL default '0' AFTER guest_vote;
---#
---# Fixing guest voter tallys on existing polls...
---{
$request = upgrade_query("
SELECT p.id_poll, count(lp.id_member) as guest_voters
FROM {$db_prefix}polls AS p
LEFT JOIN {$db_prefix}log_polls AS lp ON (lp.id_poll = p.id_poll AND lp.id_member = 0)
WHERE lp.id_member = 0
AND p.num_guest_voters = 0
GROUP BY p.id_poll");
while ($request && $row = $smcFunc['db_fetch_assoc']($request))
upgrade_query("
UPDATE {$db_prefix}polls
SET num_guest_voters = ". $row['guest_voters']. "
WHERE id_poll = " . $row['id_poll'] . "
AND num_guest_voters = 0");
---}
---#
/******************************************************************************/
--- Changing all tinytext columns to varchar(255).
/******************************************************************************/
---# Changing all tinytext columns to varchar(255)...
---{
// The array holding all the changes.
$nameChanges = array(
'admin_info_files' => array(
'filename' => 'filename filename varchar(255) NOT NULL default \'\'',
'path' => 'path path varchar(255) NOT NULL default \'\'',
'parameters' => 'parameters parameters varchar(255) NOT NULL default \'\'',
'filetype' => 'filetype filetype varchar(255) NOT NULL default \'\'',
),
'attachments' => array(
'filename' => 'filename filename varchar(255) NOT NULL default \'\'',
),
'ban_groups' => array(
'reason' => 'reason reason varchar(255) NOT NULL default \'\'',
),
'ban_items' => array(
'hostname' => 'hostname hostname varchar(255) NOT NULL default \'\'',
'email_address' => 'email_address email_address varchar(255) NOT NULL default \'\'',
),
'boards' => array(
'name' => 'name name varchar(255) NOT NULL default \'\'',
),
'categories' => array(
'name' => 'name name varchar(255) NOT NULL default \'\'',
),
'custom_fields' => array(
'field_desc' => 'field_desc field_desc varchar(255) NOT NULL default \'\'',
'mask' => 'mask mask varchar(255) NOT NULL default \'\'',
'default_value' => 'default_value default_value varchar(255) NOT NULL default \'\'',
),
'log_banned' => array(
'email' => 'email email varchar(255) NOT NULL default \'\'',
),
'log_comments' => array(
'recipient_name' => 'recipient_name recipient_name varchar(255) NOT NULL default \'\'',
),
'log_errors' => array(
'file' => 'file file varchar(255) NOT NULL default \'\'',
),
'log_member_notices' => array(
'subject' => 'subject subject varchar(255) NOT NULL default \'\'',
),
'log_packages' => array(
'filename' => 'filename filename varchar(255) NOT NULL default \'\'',
'package_id' => 'package_id package_id varchar(255) NOT NULL default \'\'',
'name' => 'name name varchar(255) NOT NULL default \'\'',
'version' => 'version version varchar(255) NOT NULL default \'\'',
'member_installed' => 'member_installed member_installed varchar(255) NOT NULL default \'\'',
'member_removed' => 'member_removed member_removed varchar(255) NOT NULL default \'\'',
'themes_installed' => 'themes_installed themes_installed varchar(255) NOT NULL default \'\'',
),
'log_reported' => array(
'membername' => 'membername membername varchar(255) NOT NULL default \'\'',
'subject' => 'subject subject varchar(255) NOT NULL default \'\'',
),
'log_reported_comments' => array(
'membername' => 'membername membername varchar(255) NOT NULL default \'\'',
'comment' => 'comment comment varchar(255) NOT NULL default \'\'',
),
'log_spider_hits' => array(
'url' => 'url url varchar(255) NOT NULL default \'\'',
),
'log_subscribed' => array(
'vendor_ref' => 'vendor_ref vendor_ref varchar(255) NOT NULL default \'\'',
),
'mail_queue' => array(
'recipient' => 'recipient recipient varchar(255) NOT NULL default \'\'',
'subject' => 'subject subject varchar(255) NOT NULL default \'\'',
),
'membergroups' => array(
'stars' => 'stars stars varchar(255) NOT NULL default \'\'',
),
'members' => array(
'lngfile' => 'lngfile lngfile varchar(255) NOT NULL default \'\'',
'real_name' => 'real_name real_name varchar(255) NOT NULL default \'\'',
'pm_ignore_list' => 'pm_ignore_list pm_ignore_list varchar(255) NOT NULL default \'\'',
'email_address' => 'email_address email_address varchar(255) NOT NULL default \'\'',
'personal_text' => 'personal_text personal_text varchar(255) NOT NULL default \'\'',
'website_title' => 'website_title website_title varchar(255) NOT NULL default \'\'',
'website_url' => 'website_url website_url varchar(255) NOT NULL default \'\'',
'location' => 'location location varchar(255) NOT NULL default \'\'',
'icq' => 'icq icq varchar(255) NOT NULL default \'\'',
'aim' => 'aim aim varchar(255) NOT NULL default \'\'',
'msn' => 'msn msn varchar(255) NOT NULL default \'\'',
'avatar' => 'avatar avatar varchar(255) NOT NULL default \'\'',
'usertitle' => 'usertitle usertitle varchar(255) NOT NULL default \'\'',
'member_ip' => 'member_ip member_ip varchar(255) NOT NULL default \'\'',
'member_ip2' => 'member_ip2 member_ip2 varchar(255) NOT NULL default \'\'',
'secret_question' => 'secret_question secret_question varchar(255) NOT NULL default \'\'',
'additional_groups' => 'additional_groups additional_groups varchar(255) NOT NULL default \'\'',
),
'messages' => array(
'subject' => 'subject subject varchar(255) NOT NULL default \'\'',
'poster_name' => 'poster_name poster_name varchar(255) NOT NULL default \'\'',
'poster_email' => 'poster_email poster_email varchar(255) NOT NULL default \'\'',
'poster_ip' => 'poster_ip poster_ip varchar(255) NOT NULL default \'\'',
'modified_name' => 'modified_name modified_name varchar(255) NOT NULL default \'\'',
),
'openid_assoc' => array(
'handle' => 'handle handle varchar(255) NOT NULL default \'\'',
),
'package_servers' => array(
'name' => 'name name varchar(255) NOT NULL default \'\'',
'url' => 'url url varchar(255) NOT NULL default \'\'',
),
'permission_profiles' => array(
'profile_name' => 'profile_name profile_name varchar(255) NOT NULL default \'\'',
),
'personal_messages' => array(
'from_name' => 'from_name from_name varchar(255) NOT NULL default \'\'',
'subject' => 'subject subject varchar(255) NOT NULL default \'\'',
),
'polls' => array(
'question' => 'question question varchar(255) NOT NULL default \'\'',
'poster_name' => 'poster_name poster_name varchar(255) NOT NULL default \'\'',
),
'poll_choices' => array(
'label' => 'label label varchar(255) NOT NULL default \'\'',
),
'settings' => array(
'variable' => 'variable variable varchar(255) NOT NULL default \'\'',
),
'spiders' => array(
'spider_name' => 'spider_name spider_name varchar(255) NOT NULL default \'\'',
'user_agent' => 'user_agent user_agent varchar(255) NOT NULL default \'\'',
'ip_info' => 'ip_info ip_info varchar(255) NOT NULL default \'\'',
),
'subscriptions' => array(
'description' => 'description description varchar(255) NOT NULL default \'\'',
),
'themes' => array(
'variable' => 'variable variable varchar(255) NOT NULL default \'\'',
),
);
$_GET['ren_col'] = isset($_GET['ren_col']) ? (int) $_GET['ren_col'] : 0;
$step_progress['name'] = 'Changing tinytext columns to varchar(255)';
$step_progress['current'] = $_GET['ren_col'];
$step_progress['total'] = count($nameChanges);
$count = 0;
// Now do every table...
foreach ($nameChanges as $table_name => $table)
{
// Already done this?
$count++;
if ($_GET['ren_col'] > $count)
continue;
$_GET['ren_col'] = $count;
// Check the table exists!
$request = upgrade_query("
SHOW TABLES
LIKE '{$db_prefix}$table_name'");
if (mysql_num_rows($request) == 0)
{
mysql_free_result($request);
continue;
}
mysql_free_result($request);
// Converting is intensive, so make damn sure that we need to do it.
$request = upgrade_query("
SHOW FIELDS
FROM `{$db_prefix}$table_name`");
$tinytextColumns = array();
while($row = mysql_fetch_assoc($request))
{
// Tinytext detected so store column name.
if ($row['Type'] == 'tinytext')
$tinytextColumns[$row['Field']] = $row['Field'];
}
mysql_free_result($request);
// Check each column!
$actualChanges = array();
foreach ($table as $colname => $coldef)
{
// Column was not detected as tinytext so skip it
// Either it was already converted or was changed eg text (so do not break it)
if (!isset($tinytextColumns[$colname]))
continue;
$change = array(
'table' => $table_name,
'name' => $colname,
'type' => 'column',
'method' => 'change_remove',
'text' => 'CHANGE ' . $coldef,
);
if (protected_alter($change, $substep, true) == false)
$actualChanges[] = ' CHANGE COLUMN ' . $coldef;
}
// Do the query - if it needs doing.
if (!empty($actualChanges))
{
$change = array(
'table' => $table_name,
'name' => 'na',
'type' => 'table',
'method' => 'full_change',
'text' => implode(', ', $actualChanges),
);
// Here we go - hold on!
protected_alter($change, $substep);
}
// Update where we are!
$step_progress['current'] = $_GET['ren_col'];
}
// All done!
unset($_GET['ren_col']);
---}
---#
/******************************************************************************/
--- Adding new personal message setting.
/******************************************************************************/
---# Adding column that stores the PM receiving setting...
ALTER TABLE {$db_prefix}members
ADD COLUMN pm_receive_from tinyint(4) unsigned NOT NULL default '1';
---#
---# Enable the buddy and ignore lists if we have not done so thus far...
---{
// Don't do this if we've done this already.
if (empty($modSettings['dont_repeat_buddylists']))
{
// Make sure the pm_receive_from column has the right default value - early adoptors might have a '0' set here.
upgrade_query("
ALTER TABLE {$db_prefix}members
CHANGE pm_receive_from pm_receive_from tinyint(3) unsigned NOT NULL default '1'");
// Update previous ignore lists if they're set to ignore all.
upgrade_query("
UPDATE {$db_prefix}members
SET pm_receive_from = 3, pm_ignore_list = ''
WHERE pm_ignore_list = '*'");
// Ignore posts made by ignored users by default.
upgrade_query("
REPLACE INTO {$db_prefix}themes
(id_member, id_theme, variable, value)
VALUES
(-1, 1, 'posts_apply_ignore_list', '1')");
// Enable buddy and ignore lists, and make sure not to skip this step next time we run this.
upgrade_query("
REPLACE INTO {$db_prefix}settings
(variable, value)
VALUES
('enable_buddylist', '1'),
('dont_repeat_buddylists', '1')");
}
// And yet, and yet... We might have a small hiccup here...
if (!empty($modSettings['dont_repeat_buddylists']) && !isset($modSettings['enable_buddylist']))
{
// Correct RC3 adopters setting here...
if (isset($modSettings['enable_buddylists']))
{
upgrade_query("
REPLACE INTO {$db_prefix}settings
(variable, value)
VALUES
('enable_buddylist', '" . $modSettings['enable_buddylists'] . "')");
}
else
{
// This should never happen :)
upgrade_query("
REPLACE INTO {$db_prefix}settings
(variable, value)
VALUES
('enable_buddylist', '1')");
}
}
---}
---#
/******************************************************************************/
--- Adding settings for attachments and avatars.
/******************************************************************************/
---# Add new security settings for attachments and avatars...
---{
// Don't do this if we've done this already.
if (!isset($modSettings['attachment_image_reencode']))
{
// Enable image re-encoding by default.
upgrade_query("
REPLACE INTO {$db_prefix}settings
(variable, value)
VALUES
('attachment_image_reencode', '1')");
}
if (!isset($modSettings['attachment_image_paranoid']))
{
// Disable draconic checks by default.
upgrade_query("
REPLACE INTO {$db_prefix}settings
(variable, value)
VALUES
('attachment_image_paranoid', '0')");
}
if (!isset($modSettings['avatar_reencode']))
{
// Enable image re-encoding by default.
upgrade_query("
REPLACE INTO {$db_prefix}settings
(variable, value)
VALUES
('avatar_reencode', '1')");
}
if (!isset($modSettings['avatar_paranoid']))
{
// Disable draconic checks by default.
upgrade_query("
REPLACE INTO {$db_prefix}settings
(variable, value)
VALUES
('avatar_paranoid', '0')");
}
---}
---#
---# Add other attachment settings...
---{
if (!isset($modSettings['attachment_thumb_png']))
{
// Make image attachment thumbnail as PNG by default.
upgrade_query("
REPLACE INTO {$db_prefix}settings
(variable, value)
VALUES
('attachment_thumb_png', '1')");
}
---}
---#
/******************************************************************************/
--- Installing new default theme...
/******************************************************************************/
---# Installing theme settings...
---{
// This is Grudge's secret "I'm not a developer" theme install code - keep this quiet ;)
// Firstly, I'm going out of my way to not do this twice!
if ((!isset($modSettings['smfVersion']) || $modSettings['smfVersion'] <= '2.0 RC5' || $modSettings['smfVersion'] === '2.0 a') && empty($modSettings['dont_repeat_theme_core']))
{
// Check it's not already here, just in case.
$theme_request = upgrade_query("
SELECT id_theme
FROM {$db_prefix}themes
WHERE variable = 'theme_dir'
AND value LIKE '%core'");
// Only do the upgrade if it doesn't find the theme already.
if (mysql_num_rows($theme_request) == 0)
{
// Try to get some settings from the current default theme.
$request = upgrade_query("
SELECT t1.value AS theme_dir, t2.value AS theme_url, t3.value AS images_url
FROM ({$db_prefix}themes AS t1, {$db_prefix}themes AS t2, {$db_prefix}themes AS t3)
WHERE t1.id_theme = 1
AND t1.id_member = 0
AND t1.variable = 'theme_dir'
AND t2.id_theme = 1
AND t2.id_member = 0
AND t2.variable = 'theme_url'
AND t3.id_theme = 1
AND t3.id_member = 0
AND t3.variable = 'images_url'
LIMIT 1");
if (mysql_num_rows($request) != 0)
{
$curve = mysql_fetch_assoc($request);
if (substr_count($curve['theme_dir'], 'default') === 1)
$core['theme_dir'] = strtr($curve['theme_dir'], array('default' => 'core'));
if (substr_count($curve['theme_url'], 'default') === 1)
$core['theme_url'] = strtr($curve['theme_url'], array('default' => 'core'));
if (substr_count($curve['images_url'], 'default') === 1)
$core['images_url'] = strtr($curve['images_url'], array('default' => 'core'));
}
mysql_free_result($request);
if (!isset($core['theme_dir']))
$core['theme_dir'] = addslashes($GLOBALS['boarddir']) . '/Themes/core';
if (!isset($core['theme_url']))
$core['theme_url'] = $GLOBALS['boardurl'] . '/Themes/core';
if (!isset($core['images_url']))
$core['images_url'] = $GLOBALS['boardurl'] . '/Themes/core/images';
// Get an available id_theme first...
$request = upgrade_query("
SELECT MAX(id_theme) + 1
FROM {$db_prefix}themes");
list ($id_core_theme) = mysql_fetch_row($request);
mysql_free_result($request);
// Insert the core theme into the tables.
upgrade_query("
INSERT INTO {$db_prefix}themes
(id_member, id_theme, variable, value)
VALUES
(0, $id_core_theme, 'name', 'Core Theme'),
(0, $id_core_theme, 'theme_url', '$core[theme_url]'),
(0, $id_core_theme, 'images_url', '$core[images_url]'),
(0, $id_core_theme, 'theme_dir', '$core[theme_dir]')");
// Update the name of the default theme in the database.
upgrade_query("
UPDATE {$db_prefix}themes
SET value = 'SMF Default Theme - Curve'
WHERE id_theme = 1
AND variable = 'name'");
// If known themes aren't set, let's just pick all themes available.
if (empty($modSettings['knownThemes']))
{
$request = upgrade_query("
SELECT DISTINCT id_theme
FROM {$db_prefix}themes");
$themes = array();
while ($row = mysql_fetch_assoc($request))
$themes[] = $row['id_theme'];
$modSettings['knownThemes'] = implode(',', $themes);
upgrade_query("
UPDATE {$db_prefix}settings
SET value = '$modSettings[knownThemes]'
WHERE variable = 'knownThemes'");
}
// Known themes.
$allThemes = explode(',', $modSettings['knownThemes']);
$allThemes[] = $id_core_theme;
$newSettings = array();
$newSettings[] = "('knownThemes', '" . implode(',', $allThemes) . "')";
upgrade_query("
REPLACE INTO {$db_prefix}settings
(variable, value)
VALUES
" . implode(', ', $newSettings));
// The other themes used to use core as their base theme.
if (isset($core['theme_dir']) && isset($core['theme_url']))
{
$coreBasedThemes = array_diff($allThemes, array(1));
// Exclude the themes that already have a base_theme_dir.
$request = upgrade_query("
SELECT DISTINCT id_theme
FROM {$db_prefix}themes
WHERE variable = 'base_theme_dir'");
while ($row = mysql_fetch_assoc($request))
$coreBasedThemes = array_diff($coreBasedThemes, array($row['id_theme']));
mysql_free_result($request);
// Only base themes if there are templates that need a fall-back.
$insertRows = array();
$request = upgrade_query("
SELECT id_theme, value AS theme_dir
FROM {$db_prefix}themes
WHERE id_theme IN (" . implode(', ', $coreBasedThemes) . ")
AND id_member = 0
AND variable = 'theme_dir'");
while ($row = mysql_fetch_assoc($request))
{
if (!file_exists($row['theme_dir'] . '/BoardIndex.template.php') || !file_exists($row['theme_dir'] . '/Display.template.php') || !file_exists($row['theme_dir'] . '/index.template.php') || !file_exists($row['theme_dir'] . '/MessageIndex.template.php') || !file_exists($row['theme_dir'] . '/Settings.template.php'))
{
$insertRows[] = "(0, $row[id_theme], 'base_theme_dir', '" . addslashes($core['theme_dir']) . "')";
$insertRows[] = "(0, $row[id_theme], 'base_theme_url', '" . addslashes($core['theme_url']) . "')";
}
}
mysql_free_result($request);
if (!empty($insertRows))
upgrade_query("
INSERT IGNORE INTO {$db_prefix}themes
(id_member, id_theme, variable, value)
VALUES
" . implode(',
', $insertRows));
}
}
mysql_free_result($theme_request);
// This ain't running twice either.
upgrade_query("
REPLACE INTO {$db_prefix}settings
(variable, value)
VALUES
('dont_repeat_theme_core', '1')");
}
---}
---#
/******************************************************************************/
--- Installing new smileys sets...
/******************************************************************************/
---# Installing new smiley sets...
---{
// Don't do this twice!
if (empty($modSettings['installed_new_smiley_sets_20']))
{
// First, the entries.
upgrade_query("
UPDATE {$db_prefix}settings
SET value = CONCAT(value, ',aaron,akyhne')
WHERE variable = 'smiley_sets_known'");
// Second, the names.
upgrade_query("
UPDATE {$db_prefix}settings
SET value = CONCAT(value, '\nAaron\nAkyhne')
WHERE variable = 'smiley_sets_names'");
// This ain't running twice either.
upgrade_query("
REPLACE INTO {$db_prefix}settings
(variable, value)
VALUES
('installed_new_smiley_sets_20', '1')");
}
---}
---#
/******************************************************************************/
--- Adding new indexes to the topics table.
/******************************************************************************/
---# Adding index member_started...
ALTER TABLE {$db_prefix}topics
ADD INDEX member_started (id_member_started, id_board);
---#
---# Adding index last_message_sticky...
ALTER TABLE {$db_prefix}topics
ADD INDEX last_message_sticky (id_board, is_sticky, id_last_msg);
---#
---# Adding index board_news...
ALTER TABLE {$db_prefix}topics
ADD INDEX board_news (id_board, id_first_msg);
---#
/******************************************************************************/
--- Adding new indexes to members table.
/******************************************************************************/
---# Adding index on total_time_logged_in...
ALTER TABLE {$db_prefix}members
ADD INDEX total_time_logged_in (total_time_logged_in);
---#
---# Adding index on id_theme...
ALTER TABLE {$db_prefix}members
ADD INDEX id_theme (id_theme);
---#
---# Dropping index on real_name(30) ...
---{
// Detect existing index with limited length
$request = upgrade_query("
SHOW INDEXES
FROM {$db_prefix}members"
);
// Drop the existing index before we recreate it.
while ($row = mysql_fetch_assoc($request))
{
if ($row['Key_name'] === 'real_name' && $row['Sub_part'] == 30)
{
upgrade_query("
ALTER TABLE {$db_prefix}members
DROP INDEX real_name"
);
break;
}
}
mysql_free_result($request);
---}
---#
---# Adding index on real_name...
ALTER TABLE {$db_prefix}members
ADD INDEX real_name (real_name);
---#
---# Dropping index member_name(30)...
---{
// Detect existing index with limited length
$request = upgrade_query("
SHOW INDEXES
FROM {$db_prefix}members"
);
// Drop the existing index before we recreate it.
while ($row = mysql_fetch_assoc($request))
{
if ($row['Key_name'] === 'member_name' && $row['Sub_part'] == 30)
{
upgrade_query("
ALTER TABLE {$db_prefix}members
DROP INDEX member_name"
);
break;
}
}
mysql_free_result($request);
---}
---#
---# Adding index on member_name...
ALTER TABLE {$db_prefix}members
ADD INDEX member_name (member_name);
---#
/******************************************************************************/
--- Adding new indexes to messages table.
/******************************************************************************/
---# Adding index id_member_msg...
ALTER TABLE {$db_prefix}messages
ADD INDEX id_member_msg (id_member, approved, id_msg);
---#
---# Adding index current_topic...
ALTER TABLE {$db_prefix}messages
ADD INDEX current_topic (id_topic, id_msg, id_member, approved);
---#
---# Adding index related_ip...
ALTER TABLE {$db_prefix}messages
ADD INDEX related_ip (id_member, poster_ip, id_msg);
---#
/******************************************************************************/
--- Adding new indexes to attachments table.
/******************************************************************************/
---# Adding index on attachment_type...
ALTER TABLE {$db_prefix}attachments
ADD INDEX attachment_type (attachment_type);
---#
/******************************************************************************/
--- Dropping unnecessary indexes...
/******************************************************************************/
---# Removing index on hits...
ALTER TABLE {$db_prefix}log_activity
DROP INDEX hits;
---#
/******************************************************************************/
--- Adding extra columns to reported post comments
/******************************************************************************/
---# Adding email address and member ip columns...
ALTER TABLE {$db_prefix}log_reported_comments
ADD COLUMN member_ip varchar(255) NOT NULL default '' AFTER membername,
ADD COLUMN email_address varchar(255) NOT NULL default '' AFTER membername;
---#
/******************************************************************************/
--- Adjusting group types.
/******************************************************************************/
---# Fixing the group types.
---{
// Get the admin group type.
$request = upgrade_query("
SELECT group_type
FROM {$db_prefix}membergroups
WHERE id_group = 1
LIMIT 1");
list ($admin_group_type) = mysql_fetch_row($request);
mysql_free_result($request);
// Not protected means we haven't updated yet!
if ($admin_group_type != 1)
{
// Increase by one.
upgrade_query("
UPDATE {$db_prefix}membergroups
SET group_type = group_type + 1
WHERE group_type > 0");
}
---}
---#
---# Changing the group type for Administrator group.
UPDATE {$db_prefix}membergroups
SET group_type = 1
WHERE id_group = 1;
---#
/******************************************************************************/
--- Final clean up...
/******************************************************************************/
---# Sorting the boards...
ALTER TABLE {$db_prefix}categories
ORDER BY cat_order;
ALTER TABLE {$db_prefix}boards
ORDER BY board_order;
---#