wp/wp-admin/includes/upgrade.php
author ymh <ymh.work@gmail.com>
Wed, 06 Nov 2013 03:21:17 +0000
changeset 0 d970ebf37754
child 5 5e2f62d02dcd
permissions -rw-r--r--
first import
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     1
<?php
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     2
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     3
 * WordPress Upgrade API
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     4
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     5
 * Most of the functions are pluggable and can be overwritten
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     6
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     7
 * @package WordPress
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     8
 * @subpackage Administration
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     9
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    10
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
/** Include user install customize script. */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
if ( file_exists(WP_CONTENT_DIR . '/install.php') )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
	require (WP_CONTENT_DIR . '/install.php');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
/** WordPress Administration API */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
require_once(ABSPATH . 'wp-admin/includes/admin.php');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
/** WordPress Schema API */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
require_once(ABSPATH . 'wp-admin/includes/schema.php');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
if ( !function_exists('wp_install') ) :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    23
 * Installs the blog
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    24
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    25
 * {@internal Missing Long Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    26
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    27
 * @since 2.1.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    28
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    29
 * @param string $blog_title Blog title.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    30
 * @param string $user_name User's username.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    31
 * @param string $user_email User's email.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    32
 * @param bool $public Whether blog is public.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    33
 * @param null $deprecated Optional. Not used.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    34
 * @param string $user_password Optional. User's chosen password. Will default to a random password.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    35
 * @return array Array keys 'url', 'user_id', 'password', 'password_message'.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    36
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    37
function wp_install( $blog_title, $user_name, $user_email, $public, $deprecated = '', $user_password = '' ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    38
	if ( !empty( $deprecated ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    39
		_deprecated_argument( __FUNCTION__, '2.6' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    40
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    41
	wp_check_mysql_version();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    42
	wp_cache_flush();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    43
	make_db_current_silent();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    44
	populate_options();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    45
	populate_roles();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    46
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    47
	update_option('blogname', $blog_title);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    48
	update_option('admin_email', $user_email);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    49
	update_option('blog_public', $public);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    50
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    51
	$guessurl = wp_guess_url();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    52
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    53
	update_option('siteurl', $guessurl);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    54
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    55
	// If not a public blog, don't ping.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    56
	if ( ! $public )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    57
		update_option('default_pingback_flag', 0);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    58
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    59
	// Create default user. If the user already exists, the user tables are
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    60
	// being shared among blogs. Just set the role in that case.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    61
	$user_id = username_exists($user_name);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    62
	$user_password = trim($user_password);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    63
	$email_password = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    64
	if ( !$user_id && empty($user_password) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    65
		$user_password = wp_generate_password( 12, false );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
		$message = __('<strong><em>Note that password</em></strong> carefully! It is a <em>random</em> password that was generated just for you.');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
		$user_id = wp_create_user($user_name, $user_password, $user_email);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    68
		update_user_option($user_id, 'default_password_nag', true, true);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    69
		$email_password = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    70
	} else if ( !$user_id ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    71
		// Password has been provided
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    72
		$message = '<em>'.__('Your chosen password.').'</em>';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    73
		$user_id = wp_create_user($user_name, $user_password, $user_email);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    74
	} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    75
		$message = __('User already exists. Password inherited.');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    76
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    77
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    78
	$user = new WP_User($user_id);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    79
	$user->set_role('administrator');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    80
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    81
	wp_install_defaults($user_id);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    82
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    83
	flush_rewrite_rules();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    84
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    85
	wp_new_blog_notification($blog_title, $guessurl, $user_id, ($email_password ? $user_password : __('The password you chose during the install.') ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    86
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    87
	wp_cache_flush();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    88
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    89
	return array('url' => $guessurl, 'user_id' => $user_id, 'password' => $user_password, 'password_message' => $message);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    90
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    91
endif;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    92
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    93
if ( !function_exists('wp_install_defaults') ) :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    94
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    95
 * {@internal Missing Short Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    96
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    97
 * {@internal Missing Long Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    98
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    99
 * @since 2.1.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   100
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   101
 * @param int $user_id User ID.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   102
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   103
function wp_install_defaults($user_id) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   104
	global $wpdb, $wp_rewrite, $current_site, $table_prefix;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   105
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   106
	// Default category
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   107
	$cat_name = __('Uncategorized');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   108
	/* translators: Default category slug */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   109
	$cat_slug = sanitize_title(_x('Uncategorized', 'Default category slug'));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   110
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   111
	if ( global_terms_enabled() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   112
		$cat_id = $wpdb->get_var( $wpdb->prepare( "SELECT cat_ID FROM {$wpdb->sitecategories} WHERE category_nicename = %s", $cat_slug ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   113
		if ( $cat_id == null ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   114
			$wpdb->insert( $wpdb->sitecategories, array('cat_ID' => 0, 'cat_name' => $cat_name, 'category_nicename' => $cat_slug, 'last_updated' => current_time('mysql', true)) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   115
			$cat_id = $wpdb->insert_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   116
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   117
		update_option('default_category', $cat_id);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   118
	} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   119
		$cat_id = 1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   120
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   121
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   122
	$wpdb->insert( $wpdb->terms, array('term_id' => $cat_id, 'name' => $cat_name, 'slug' => $cat_slug, 'term_group' => 0) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   123
	$wpdb->insert( $wpdb->term_taxonomy, array('term_id' => $cat_id, 'taxonomy' => 'category', 'description' => '', 'parent' => 0, 'count' => 1));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   124
	$cat_tt_id = $wpdb->insert_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   125
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   126
	// First post
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   127
	$now = date('Y-m-d H:i:s');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   128
	$now_gmt = gmdate('Y-m-d H:i:s');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   129
	$first_post_guid = get_option('home') . '/?p=1';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   130
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   131
	if ( is_multisite() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   132
		$first_post = get_site_option( 'first_post' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   133
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   134
		if ( empty($first_post) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   135
			$first_post = __( 'Welcome to <a href="SITE_URL">SITE_NAME</a>. This is your first post. Edit or delete it, then start blogging!' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   136
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   137
		$first_post = str_replace( "SITE_URL", esc_url( network_home_url() ), $first_post );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   138
		$first_post = str_replace( "SITE_NAME", $current_site->site_name, $first_post );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   139
	} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   140
		$first_post = __('Welcome to WordPress. This is your first post. Edit or delete it, then start blogging!');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   141
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   142
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   143
	$wpdb->insert( $wpdb->posts, array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   144
								'post_author' => $user_id,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   145
								'post_date' => $now,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   146
								'post_date_gmt' => $now_gmt,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   147
								'post_content' => $first_post,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   148
								'post_excerpt' => '',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   149
								'post_title' => __('Hello world!'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   150
								/* translators: Default post slug */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   151
								'post_name' => sanitize_title( _x('hello-world', 'Default post slug') ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   152
								'post_modified' => $now,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   153
								'post_modified_gmt' => $now_gmt,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   154
								'guid' => $first_post_guid,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   155
								'comment_count' => 1,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   156
								'to_ping' => '',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   157
								'pinged' => '',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   158
								'post_content_filtered' => ''
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   159
								));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   160
	$wpdb->insert( $wpdb->term_relationships, array('term_taxonomy_id' => $cat_tt_id, 'object_id' => 1) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   161
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   162
	// Default comment
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   163
	$first_comment_author = __('Mr WordPress');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   164
	$first_comment_url = 'http://wordpress.org/';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   165
	$first_comment = __('Hi, this is a comment.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   166
To delete a comment, just log in and view the post&#039;s comments. There you will have the option to edit or delete them.');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   167
	if ( is_multisite() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   168
		$first_comment_author = get_site_option( 'first_comment_author', $first_comment_author );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   169
		$first_comment_url = get_site_option( 'first_comment_url', network_home_url() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   170
		$first_comment = get_site_option( 'first_comment', $first_comment );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   171
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   172
	$wpdb->insert( $wpdb->comments, array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   173
								'comment_post_ID' => 1,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   174
								'comment_author' => $first_comment_author,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   175
								'comment_author_email' => '',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   176
								'comment_author_url' => $first_comment_url,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   177
								'comment_date' => $now,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   178
								'comment_date_gmt' => $now_gmt,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   179
								'comment_content' => $first_comment
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   180
								));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   181
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   182
	// First Page
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   183
	$first_page = sprintf( __( "This is an example page. It's different from a blog post because it will stay in one place and will show up in your site navigation (in most themes). Most people start with an About page that introduces them to potential site visitors. It might say something like this:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   184
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   185
<blockquote>Hi there! I'm a bike messenger by day, aspiring actor by night, and this is my blog. I live in Los Angeles, have a great dog named Jack, and I like pi&#241;a coladas. (And gettin' caught in the rain.)</blockquote>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   186
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   187
...or something like this:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   188
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   189
<blockquote>The XYZ Doohickey Company was founded in 1971, and has been providing quality doohickeys to the public ever since. Located in Gotham City, XYZ employs over 2,000 people and does all kinds of awesome things for the Gotham community.</blockquote>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   190
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   191
As a new WordPress user, you should go to <a href=\"%s\">your dashboard</a> to delete this page and create new pages for your content. Have fun!" ), admin_url() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   192
	if ( is_multisite() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   193
		$first_page = get_site_option( 'first_page', $first_page );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   194
	$first_post_guid = get_option('home') . '/?page_id=2';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   195
	$wpdb->insert( $wpdb->posts, array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   196
								'post_author' => $user_id,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   197
								'post_date' => $now,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   198
								'post_date_gmt' => $now_gmt,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   199
								'post_content' => $first_page,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   200
								'post_excerpt' => '',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   201
								'post_title' => __( 'Sample Page' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   202
								/* translators: Default page slug */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   203
								'post_name' => __( 'sample-page' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   204
								'post_modified' => $now,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   205
								'post_modified_gmt' => $now_gmt,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   206
								'guid' => $first_post_guid,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   207
								'post_type' => 'page',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   208
								'to_ping' => '',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   209
								'pinged' => '',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   210
								'post_content_filtered' => ''
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   211
								));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   212
	$wpdb->insert( $wpdb->postmeta, array( 'post_id' => 2, 'meta_key' => '_wp_page_template', 'meta_value' => 'default' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   213
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   214
	// Set up default widgets for default theme.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   215
	update_option( 'widget_search', array ( 2 => array ( 'title' => '' ), '_multiwidget' => 1 ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   216
	update_option( 'widget_recent-posts', array ( 2 => array ( 'title' => '', 'number' => 5 ), '_multiwidget' => 1 ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   217
	update_option( 'widget_recent-comments', array ( 2 => array ( 'title' => '', 'number' => 5 ), '_multiwidget' => 1 ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   218
	update_option( 'widget_archives', array ( 2 => array ( 'title' => '', 'count' => 0, 'dropdown' => 0 ), '_multiwidget' => 1 ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   219
	update_option( 'widget_categories', array ( 2 => array ( 'title' => '', 'count' => 0, 'hierarchical' => 0, 'dropdown' => 0 ), '_multiwidget' => 1 ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   220
	update_option( 'widget_meta', array ( 2 => array ( 'title' => '' ), '_multiwidget' => 1 ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   221
	update_option( 'sidebars_widgets', array ( 'wp_inactive_widgets' => array (), 'sidebar-1' => array ( 0 => 'search-2', 1 => 'recent-posts-2', 2 => 'recent-comments-2', 3 => 'archives-2', 4 => 'categories-2', 5 => 'meta-2', ), 'sidebar-2' => array (),'array_version' => 3 ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   222
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   223
	if ( ! is_multisite() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   224
		update_user_meta( $user_id, 'show_welcome_panel', 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   225
	elseif ( ! is_super_admin( $user_id ) && ! metadata_exists( 'user', $user_id, 'show_welcome_panel' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   226
		update_user_meta( $user_id, 'show_welcome_panel', 2 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   227
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   228
	if ( is_multisite() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   229
		// Flush rules to pick up the new page.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   230
		$wp_rewrite->init();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   231
		$wp_rewrite->flush_rules();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   232
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   233
		$user = new WP_User($user_id);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   234
		$wpdb->update( $wpdb->options, array('option_value' => $user->user_email), array('option_name' => 'admin_email') );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   235
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   236
		// Remove all perms except for the login user.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   237
		$wpdb->query( $wpdb->prepare("DELETE FROM $wpdb->usermeta WHERE user_id != %d AND meta_key = %s", $user_id, $table_prefix.'user_level') );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   238
		$wpdb->query( $wpdb->prepare("DELETE FROM $wpdb->usermeta WHERE user_id != %d AND meta_key = %s", $user_id, $table_prefix.'capabilities') );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   239
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   240
		// Delete any caps that snuck into the previously active blog. (Hardcoded to blog 1 for now.) TODO: Get previous_blog_id.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   241
		if ( !is_super_admin( $user_id ) && $user_id != 1 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   242
			$wpdb->delete( $wpdb->usermeta, array( 'user_id' => $user_id , 'meta_key' => $wpdb->base_prefix.'1_capabilities' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   243
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   244
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   245
endif;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   246
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   247
if ( !function_exists('wp_new_blog_notification') ) :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   248
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   249
 * {@internal Missing Short Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   250
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   251
 * {@internal Missing Long Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   252
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   253
 * @since 2.1.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   254
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   255
 * @param string $blog_title Blog title.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   256
 * @param string $blog_url Blog url.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   257
 * @param int $user_id User ID.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   258
 * @param string $password User's Password.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   259
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   260
function wp_new_blog_notification($blog_title, $blog_url, $user_id, $password) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   261
	$user = new WP_User( $user_id );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   262
	$email = $user->user_email;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   263
	$name = $user->user_login;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   264
	$message = sprintf(__("Your new WordPress site has been successfully set up at:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   265
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   266
%1\$s
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   267
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   268
You can log in to the administrator account with the following information:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   269
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   270
Username: %2\$s
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   271
Password: %3\$s
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   272
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   273
We hope you enjoy your new site. Thanks!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   274
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   275
--The WordPress Team
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   276
http://wordpress.org/
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   277
"), $blog_url, $name, $password);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   278
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   279
	@wp_mail($email, __('New WordPress Site'), $message);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   280
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   281
endif;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   282
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   283
if ( !function_exists('wp_upgrade') ) :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   284
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   285
 * Run WordPress Upgrade functions.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   286
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   287
 * {@internal Missing Long Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   288
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   289
 * @since 2.1.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   290
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   291
 * @return null
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   292
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   293
function wp_upgrade() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   294
	global $wp_current_db_version, $wp_db_version, $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   295
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   296
	$wp_current_db_version = __get_option('db_version');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   297
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   298
	// We are up-to-date. Nothing to do.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   299
	if ( $wp_db_version == $wp_current_db_version )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   300
		return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   301
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   302
	if ( ! is_blog_installed() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   303
		return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   304
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   305
	wp_check_mysql_version();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   306
	wp_cache_flush();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   307
	pre_schema_upgrade();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   308
	make_db_current_silent();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   309
	upgrade_all();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   310
	if ( is_multisite() && is_main_site() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   311
		upgrade_network();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   312
	wp_cache_flush();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   313
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   314
	if ( is_multisite() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   315
		if ( $wpdb->get_row( "SELECT blog_id FROM {$wpdb->blog_versions} WHERE blog_id = '{$wpdb->blogid}'" ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   316
			$wpdb->query( "UPDATE {$wpdb->blog_versions} SET db_version = '{$wp_db_version}' WHERE blog_id = '{$wpdb->blogid}'" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   317
		else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   318
			$wpdb->query( "INSERT INTO {$wpdb->blog_versions} ( `blog_id` , `db_version` , `last_updated` ) VALUES ( '{$wpdb->blogid}', '{$wp_db_version}', NOW());" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   319
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   320
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   321
endif;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   322
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   323
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   324
 * Functions to be called in install and upgrade scripts.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   325
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   326
 * {@internal Missing Long Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   327
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   328
 * @since 1.0.1
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   329
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   330
function upgrade_all() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   331
	global $wp_current_db_version, $wp_db_version;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   332
	$wp_current_db_version = __get_option('db_version');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   333
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   334
	// We are up-to-date. Nothing to do.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   335
	if ( $wp_db_version == $wp_current_db_version )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   336
		return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   337
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   338
	// If the version is not set in the DB, try to guess the version.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   339
	if ( empty($wp_current_db_version) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   340
		$wp_current_db_version = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   341
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   342
		// If the template option exists, we have 1.5.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   343
		$template = __get_option('template');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   344
		if ( !empty($template) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   345
			$wp_current_db_version = 2541;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   346
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   347
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   348
	if ( $wp_current_db_version < 6039 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   349
		upgrade_230_options_table();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   350
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   351
	populate_options();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   352
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   353
	if ( $wp_current_db_version < 2541 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   354
		upgrade_100();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   355
		upgrade_101();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   356
		upgrade_110();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   357
		upgrade_130();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   358
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   359
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   360
	if ( $wp_current_db_version < 3308 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   361
		upgrade_160();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   362
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   363
	if ( $wp_current_db_version < 4772 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   364
		upgrade_210();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   365
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   366
	if ( $wp_current_db_version < 4351 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   367
		upgrade_old_slugs();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   368
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   369
	if ( $wp_current_db_version < 5539 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   370
		upgrade_230();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   371
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   372
	if ( $wp_current_db_version < 6124 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   373
		upgrade_230_old_tables();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   374
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   375
	if ( $wp_current_db_version < 7499 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   376
		upgrade_250();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   377
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   378
	if ( $wp_current_db_version < 7935 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   379
		upgrade_252();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   380
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   381
	if ( $wp_current_db_version < 8201 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   382
		upgrade_260();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   383
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   384
	if ( $wp_current_db_version < 8989 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   385
		upgrade_270();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   386
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   387
	if ( $wp_current_db_version < 10360 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   388
		upgrade_280();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   389
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   390
	if ( $wp_current_db_version < 11958 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   391
		upgrade_290();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   392
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   393
	if ( $wp_current_db_version < 15260 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   394
		upgrade_300();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   395
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   396
	if ( $wp_current_db_version < 19389 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   397
		upgrade_330();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   398
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   399
	if ( $wp_current_db_version < 20080 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   400
		upgrade_340();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   401
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   402
	if ( $wp_current_db_version < 22422 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   403
		upgrade_350();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   404
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   405
	if ( $wp_current_db_version < 25824 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   406
		upgrade_370();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   407
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   408
	maybe_disable_link_manager();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   409
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   410
	maybe_disable_automattic_widgets();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   411
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   412
	update_option( 'db_version', $wp_db_version );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   413
	update_option( 'db_upgraded', true );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   414
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   415
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   416
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   417
 * Execute changes made in WordPress 1.0.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   418
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   419
 * @since 1.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   420
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   421
function upgrade_100() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   422
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   423
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   424
	// Get the title and ID of every post, post_name to check if it already has a value
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   425
	$posts = $wpdb->get_results("SELECT ID, post_title, post_name FROM $wpdb->posts WHERE post_name = ''");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   426
	if ($posts) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   427
		foreach($posts as $post) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   428
			if ('' == $post->post_name) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   429
				$newtitle = sanitize_title($post->post_title);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   430
				$wpdb->query( $wpdb->prepare("UPDATE $wpdb->posts SET post_name = %s WHERE ID = %d", $newtitle, $post->ID) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   431
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   432
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   433
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   434
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   435
	$categories = $wpdb->get_results("SELECT cat_ID, cat_name, category_nicename FROM $wpdb->categories");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   436
	foreach ($categories as $category) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   437
		if ('' == $category->category_nicename) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   438
			$newtitle = sanitize_title($category->cat_name);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   439
			$wpdb->update( $wpdb->categories, array('category_nicename' => $newtitle), array('cat_ID' => $category->cat_ID) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   440
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   441
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   442
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   443
	$wpdb->query("UPDATE $wpdb->options SET option_value = REPLACE(option_value, 'wp-links/links-images/', 'wp-images/links/')
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   444
	WHERE option_name LIKE 'links_rating_image%'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   445
	AND option_value LIKE 'wp-links/links-images/%'");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   446
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   447
	$done_ids = $wpdb->get_results("SELECT DISTINCT post_id FROM $wpdb->post2cat");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   448
	if ($done_ids) :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   449
		foreach ($done_ids as $done_id) :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   450
			$done_posts[] = $done_id->post_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   451
		endforeach;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   452
		$catwhere = ' AND ID NOT IN (' . implode(',', $done_posts) . ')';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   453
	else:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   454
		$catwhere = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   455
	endif;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   456
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   457
	$allposts = $wpdb->get_results("SELECT ID, post_category FROM $wpdb->posts WHERE post_category != '0' $catwhere");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   458
	if ($allposts) :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   459
		foreach ($allposts as $post) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   460
			// Check to see if it's already been imported
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   461
			$cat = $wpdb->get_row( $wpdb->prepare("SELECT * FROM $wpdb->post2cat WHERE post_id = %d AND category_id = %d", $post->ID, $post->post_category) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   462
			if (!$cat && 0 != $post->post_category) { // If there's no result
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   463
				$wpdb->insert( $wpdb->post2cat, array('post_id' => $post->ID, 'category_id' => $post->post_category) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   464
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   465
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   466
	endif;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   467
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   468
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   469
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   470
 * Execute changes made in WordPress 1.0.1.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   471
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   472
 * @since 1.0.1
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   473
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   474
function upgrade_101() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   475
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   476
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   477
	// Clean up indices, add a few
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   478
	add_clean_index($wpdb->posts, 'post_name');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   479
	add_clean_index($wpdb->posts, 'post_status');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   480
	add_clean_index($wpdb->categories, 'category_nicename');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   481
	add_clean_index($wpdb->comments, 'comment_approved');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   482
	add_clean_index($wpdb->comments, 'comment_post_ID');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   483
	add_clean_index($wpdb->links , 'link_category');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   484
	add_clean_index($wpdb->links , 'link_visible');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   485
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   486
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   487
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   488
 * Execute changes made in WordPress 1.2.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   489
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   490
 * @since 1.2.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   491
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   492
function upgrade_110() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   493
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   494
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   495
	// Set user_nicename.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   496
	$users = $wpdb->get_results("SELECT ID, user_nickname, user_nicename FROM $wpdb->users");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   497
	foreach ($users as $user) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   498
		if ('' == $user->user_nicename) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   499
			$newname = sanitize_title($user->user_nickname);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   500
			$wpdb->update( $wpdb->users, array('user_nicename' => $newname), array('ID' => $user->ID) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   501
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   502
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   503
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   504
	$users = $wpdb->get_results("SELECT ID, user_pass from $wpdb->users");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   505
	foreach ($users as $row) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   506
		if (!preg_match('/^[A-Fa-f0-9]{32}$/', $row->user_pass)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   507
			$wpdb->update( $wpdb->users, array('user_pass' => md5($row->user_pass)), array('ID' => $row->ID) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   508
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   509
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   510
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   511
	// Get the GMT offset, we'll use that later on
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   512
	$all_options = get_alloptions_110();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   513
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   514
	$time_difference = $all_options->time_difference;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   515
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   516
		$server_time = time()+date('Z');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   517
	$weblogger_time = $server_time + $time_difference * HOUR_IN_SECONDS;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   518
	$gmt_time = time();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   519
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   520
	$diff_gmt_server = ($gmt_time - $server_time) / HOUR_IN_SECONDS;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   521
	$diff_weblogger_server = ($weblogger_time - $server_time) / HOUR_IN_SECONDS;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   522
	$diff_gmt_weblogger = $diff_gmt_server - $diff_weblogger_server;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   523
	$gmt_offset = -$diff_gmt_weblogger;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   524
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   525
	// Add a gmt_offset option, with value $gmt_offset
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   526
	add_option('gmt_offset', $gmt_offset);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   527
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   528
	// Check if we already set the GMT fields (if we did, then
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   529
	// MAX(post_date_gmt) can't be '0000-00-00 00:00:00'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   530
	// <michel_v> I just slapped myself silly for not thinking about it earlier
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   531
	$got_gmt_fields = ! ($wpdb->get_var("SELECT MAX(post_date_gmt) FROM $wpdb->posts") == '0000-00-00 00:00:00');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   532
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   533
	if (!$got_gmt_fields) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   534
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   535
		// Add or subtract time to all dates, to get GMT dates
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   536
		$add_hours = intval($diff_gmt_weblogger);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   537
		$add_minutes = intval(60 * ($diff_gmt_weblogger - $add_hours));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   538
		$wpdb->query("UPDATE $wpdb->posts SET post_date_gmt = DATE_ADD(post_date, INTERVAL '$add_hours:$add_minutes' HOUR_MINUTE)");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   539
		$wpdb->query("UPDATE $wpdb->posts SET post_modified = post_date");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   540
		$wpdb->query("UPDATE $wpdb->posts SET post_modified_gmt = DATE_ADD(post_modified, INTERVAL '$add_hours:$add_minutes' HOUR_MINUTE) WHERE post_modified != '0000-00-00 00:00:00'");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   541
		$wpdb->query("UPDATE $wpdb->comments SET comment_date_gmt = DATE_ADD(comment_date, INTERVAL '$add_hours:$add_minutes' HOUR_MINUTE)");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   542
		$wpdb->query("UPDATE $wpdb->users SET user_registered = DATE_ADD(user_registered, INTERVAL '$add_hours:$add_minutes' HOUR_MINUTE)");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   543
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   544
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   545
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   546
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   547
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   548
 * Execute changes made in WordPress 1.5.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   549
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   550
 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   551
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   552
function upgrade_130() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   553
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   554
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   555
	// Remove extraneous backslashes.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   556
	$posts = $wpdb->get_results("SELECT ID, post_title, post_content, post_excerpt, guid, post_date, post_name, post_status, post_author FROM $wpdb->posts");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   557
	if ($posts) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   558
		foreach($posts as $post) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   559
			$post_content = addslashes(deslash($post->post_content));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   560
			$post_title = addslashes(deslash($post->post_title));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   561
			$post_excerpt = addslashes(deslash($post->post_excerpt));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   562
			if ( empty($post->guid) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   563
				$guid = get_permalink($post->ID);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   564
			else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   565
				$guid = $post->guid;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   566
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   567
			$wpdb->update( $wpdb->posts, compact('post_title', 'post_content', 'post_excerpt', 'guid'), array('ID' => $post->ID) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   568
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   569
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   570
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   571
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   572
	// Remove extraneous backslashes.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   573
	$comments = $wpdb->get_results("SELECT comment_ID, comment_author, comment_content FROM $wpdb->comments");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   574
	if ($comments) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   575
		foreach($comments as $comment) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   576
			$comment_content = deslash($comment->comment_content);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   577
			$comment_author = deslash($comment->comment_author);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   578
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   579
			$wpdb->update($wpdb->comments, compact('comment_content', 'comment_author'), array('comment_ID' => $comment->comment_ID) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   580
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   581
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   582
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   583
	// Remove extraneous backslashes.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   584
	$links = $wpdb->get_results("SELECT link_id, link_name, link_description FROM $wpdb->links");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   585
	if ($links) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   586
		foreach($links as $link) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   587
			$link_name = deslash($link->link_name);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   588
			$link_description = deslash($link->link_description);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   589
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   590
			$wpdb->update( $wpdb->links, compact('link_name', 'link_description'), array('link_id' => $link->link_id) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   591
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   592
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   593
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   594
	$active_plugins = __get_option('active_plugins');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   595
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   596
	// If plugins are not stored in an array, they're stored in the old
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   597
	// newline separated format. Convert to new format.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   598
	if ( !is_array( $active_plugins ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   599
		$active_plugins = explode("\n", trim($active_plugins));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   600
		update_option('active_plugins', $active_plugins);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   601
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   602
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   603
	// Obsolete tables
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   604
	$wpdb->query('DROP TABLE IF EXISTS ' . $wpdb->prefix . 'optionvalues');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   605
	$wpdb->query('DROP TABLE IF EXISTS ' . $wpdb->prefix . 'optiontypes');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   606
	$wpdb->query('DROP TABLE IF EXISTS ' . $wpdb->prefix . 'optiongroups');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   607
	$wpdb->query('DROP TABLE IF EXISTS ' . $wpdb->prefix . 'optiongroup_options');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   608
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   609
	// Update comments table to use comment_type
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   610
	$wpdb->query("UPDATE $wpdb->comments SET comment_type='trackback', comment_content = REPLACE(comment_content, '<trackback />', '') WHERE comment_content LIKE '<trackback />%'");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   611
	$wpdb->query("UPDATE $wpdb->comments SET comment_type='pingback', comment_content = REPLACE(comment_content, '<pingback />', '') WHERE comment_content LIKE '<pingback />%'");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   612
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   613
	// Some versions have multiple duplicate option_name rows with the same values
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   614
	$options = $wpdb->get_results("SELECT option_name, COUNT(option_name) AS dupes FROM `$wpdb->options` GROUP BY option_name");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   615
	foreach ( $options as $option ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   616
		if ( 1 != $option->dupes ) { // Could this be done in the query?
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   617
			$limit = $option->dupes - 1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   618
			$dupe_ids = $wpdb->get_col( $wpdb->prepare("SELECT option_id FROM $wpdb->options WHERE option_name = %s LIMIT %d", $option->option_name, $limit) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   619
			if ( $dupe_ids ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   620
				$dupe_ids = join($dupe_ids, ',');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   621
				$wpdb->query("DELETE FROM $wpdb->options WHERE option_id IN ($dupe_ids)");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   622
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   623
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   624
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   625
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   626
	make_site_theme();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   627
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   628
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   629
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   630
 * Execute changes made in WordPress 2.0.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   631
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   632
 * @since 2.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   633
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   634
function upgrade_160() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   635
	global $wpdb, $wp_current_db_version;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   636
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   637
	populate_roles_160();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   638
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   639
	$users = $wpdb->get_results("SELECT * FROM $wpdb->users");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   640
	foreach ( $users as $user ) :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   641
		if ( !empty( $user->user_firstname ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   642
			update_user_meta( $user->ID, 'first_name', wp_slash($user->user_firstname) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   643
		if ( !empty( $user->user_lastname ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   644
			update_user_meta( $user->ID, 'last_name', wp_slash($user->user_lastname) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   645
		if ( !empty( $user->user_nickname ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   646
			update_user_meta( $user->ID, 'nickname', wp_slash($user->user_nickname) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   647
		if ( !empty( $user->user_level ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   648
			update_user_meta( $user->ID, $wpdb->prefix . 'user_level', $user->user_level );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   649
		if ( !empty( $user->user_icq ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   650
			update_user_meta( $user->ID, 'icq', wp_slash($user->user_icq) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   651
		if ( !empty( $user->user_aim ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   652
			update_user_meta( $user->ID, 'aim', wp_slash($user->user_aim) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   653
		if ( !empty( $user->user_msn ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   654
			update_user_meta( $user->ID, 'msn', wp_slash($user->user_msn) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   655
		if ( !empty( $user->user_yim ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   656
			update_user_meta( $user->ID, 'yim', wp_slash($user->user_icq) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   657
		if ( !empty( $user->user_description ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   658
			update_user_meta( $user->ID, 'description', wp_slash($user->user_description) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   659
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   660
		if ( isset( $user->user_idmode ) ):
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   661
			$idmode = $user->user_idmode;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   662
			if ($idmode == 'nickname') $id = $user->user_nickname;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   663
			if ($idmode == 'login') $id = $user->user_login;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   664
			if ($idmode == 'firstname') $id = $user->user_firstname;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   665
			if ($idmode == 'lastname') $id = $user->user_lastname;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   666
			if ($idmode == 'namefl') $id = $user->user_firstname.' '.$user->user_lastname;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   667
			if ($idmode == 'namelf') $id = $user->user_lastname.' '.$user->user_firstname;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   668
			if (!$idmode) $id = $user->user_nickname;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   669
			$wpdb->update( $wpdb->users, array('display_name' => $id), array('ID' => $user->ID) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   670
		endif;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   671
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   672
		// FIXME: RESET_CAPS is temporary code to reset roles and caps if flag is set.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   673
		$caps = get_user_meta( $user->ID, $wpdb->prefix . 'capabilities');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   674
		if ( empty($caps) || defined('RESET_CAPS') ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   675
			$level = get_user_meta($user->ID, $wpdb->prefix . 'user_level', true);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   676
			$role = translate_level_to_role($level);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   677
			update_user_meta( $user->ID, $wpdb->prefix . 'capabilities', array($role => true) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   678
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   679
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   680
	endforeach;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   681
	$old_user_fields = array( 'user_firstname', 'user_lastname', 'user_icq', 'user_aim', 'user_msn', 'user_yim', 'user_idmode', 'user_ip', 'user_domain', 'user_browser', 'user_description', 'user_nickname', 'user_level' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   682
	$wpdb->hide_errors();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   683
	foreach ( $old_user_fields as $old )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   684
		$wpdb->query("ALTER TABLE $wpdb->users DROP $old");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   685
	$wpdb->show_errors();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   686
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   687
	// populate comment_count field of posts table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   688
	$comments = $wpdb->get_results( "SELECT comment_post_ID, COUNT(*) as c FROM $wpdb->comments WHERE comment_approved = '1' GROUP BY comment_post_ID" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   689
	if ( is_array( $comments ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   690
		foreach ($comments as $comment)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   691
			$wpdb->update( $wpdb->posts, array('comment_count' => $comment->c), array('ID' => $comment->comment_post_ID) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   692
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   693
	// Some alpha versions used a post status of object instead of attachment and put
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   694
	// the mime type in post_type instead of post_mime_type.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   695
	if ( $wp_current_db_version > 2541 && $wp_current_db_version <= 3091 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   696
		$objects = $wpdb->get_results("SELECT ID, post_type FROM $wpdb->posts WHERE post_status = 'object'");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   697
		foreach ($objects as $object) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   698
			$wpdb->update( $wpdb->posts, array(	'post_status' => 'attachment',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   699
												'post_mime_type' => $object->post_type,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   700
												'post_type' => ''),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   701
										 array( 'ID' => $object->ID ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   702
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   703
			$meta = get_post_meta($object->ID, 'imagedata', true);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   704
			if ( ! empty($meta['file']) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   705
				update_attached_file( $object->ID, $meta['file'] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   706
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   707
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   708
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   709
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   710
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   711
 * Execute changes made in WordPress 2.1.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   712
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   713
 * @since 2.1.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   714
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   715
function upgrade_210() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   716
	global $wpdb, $wp_current_db_version;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   717
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   718
	if ( $wp_current_db_version < 3506 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   719
		// Update status and type.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   720
		$posts = $wpdb->get_results("SELECT ID, post_status FROM $wpdb->posts");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   721
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   722
		if ( ! empty($posts) ) foreach ($posts as $post) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   723
			$status = $post->post_status;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   724
			$type = 'post';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   725
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   726
			if ( 'static' == $status ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   727
				$status = 'publish';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   728
				$type = 'page';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   729
			} else if ( 'attachment' == $status ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   730
				$status = 'inherit';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   731
				$type = 'attachment';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   732
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   733
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   734
			$wpdb->query( $wpdb->prepare("UPDATE $wpdb->posts SET post_status = %s, post_type = %s WHERE ID = %d", $status, $type, $post->ID) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   735
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   736
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   737
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   738
	if ( $wp_current_db_version < 3845 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   739
		populate_roles_210();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   740
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   741
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   742
	if ( $wp_current_db_version < 3531 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   743
		// Give future posts a post_status of future.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   744
		$now = gmdate('Y-m-d H:i:59');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   745
		$wpdb->query ("UPDATE $wpdb->posts SET post_status = 'future' WHERE post_status = 'publish' AND post_date_gmt > '$now'");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   746
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   747
		$posts = $wpdb->get_results("SELECT ID, post_date FROM $wpdb->posts WHERE post_status ='future'");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   748
		if ( !empty($posts) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   749
			foreach ( $posts as $post )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   750
				wp_schedule_single_event(mysql2date('U', $post->post_date, false), 'publish_future_post', array($post->ID));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   751
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   752
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   753
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   754
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   755
 * Execute changes made in WordPress 2.3.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   756
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   757
 * @since 2.3.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   758
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   759
function upgrade_230() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   760
	global $wp_current_db_version, $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   761
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   762
	if ( $wp_current_db_version < 5200 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   763
		populate_roles_230();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   764
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   765
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   766
	// Convert categories to terms.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   767
	$tt_ids = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   768
	$have_tags = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   769
	$categories = $wpdb->get_results("SELECT * FROM $wpdb->categories ORDER BY cat_ID");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   770
	foreach ($categories as $category) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   771
		$term_id = (int) $category->cat_ID;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   772
		$name = $category->cat_name;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   773
		$description = $category->category_description;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   774
		$slug = $category->category_nicename;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   775
		$parent = $category->category_parent;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   776
		$term_group = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   777
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   778
		// Associate terms with the same slug in a term group and make slugs unique.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   779
		if ( $exists = $wpdb->get_results( $wpdb->prepare("SELECT term_id, term_group FROM $wpdb->terms WHERE slug = %s", $slug) ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   780
			$term_group = $exists[0]->term_group;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   781
			$id = $exists[0]->term_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   782
			$num = 2;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   783
			do {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   784
				$alt_slug = $slug . "-$num";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   785
				$num++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   786
				$slug_check = $wpdb->get_var( $wpdb->prepare("SELECT slug FROM $wpdb->terms WHERE slug = %s", $alt_slug) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   787
			} while ( $slug_check );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   788
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   789
			$slug = $alt_slug;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   790
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   791
			if ( empty( $term_group ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   792
				$term_group = $wpdb->get_var("SELECT MAX(term_group) FROM $wpdb->terms GROUP BY term_group") + 1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   793
				$wpdb->query( $wpdb->prepare("UPDATE $wpdb->terms SET term_group = %d WHERE term_id = %d", $term_group, $id) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   794
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   795
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   796
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   797
		$wpdb->query( $wpdb->prepare("INSERT INTO $wpdb->terms (term_id, name, slug, term_group) VALUES
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   798
		(%d, %s, %s, %d)", $term_id, $name, $slug, $term_group) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   799
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   800
		$count = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   801
		if ( !empty($category->category_count) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   802
			$count = (int) $category->category_count;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   803
			$taxonomy = 'category';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   804
			$wpdb->query( $wpdb->prepare("INSERT INTO $wpdb->term_taxonomy (term_id, taxonomy, description, parent, count) VALUES ( %d, %s, %s, %d, %d)", $term_id, $taxonomy, $description, $parent, $count) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   805
			$tt_ids[$term_id][$taxonomy] = (int) $wpdb->insert_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   806
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   807
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   808
		if ( !empty($category->link_count) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   809
			$count = (int) $category->link_count;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   810
			$taxonomy = 'link_category';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   811
			$wpdb->query( $wpdb->prepare("INSERT INTO $wpdb->term_taxonomy (term_id, taxonomy, description, parent, count) VALUES ( %d, %s, %s, %d, %d)", $term_id, $taxonomy, $description, $parent, $count) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   812
			$tt_ids[$term_id][$taxonomy] = (int) $wpdb->insert_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   813
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   814
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   815
		if ( !empty($category->tag_count) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   816
			$have_tags = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   817
			$count = (int) $category->tag_count;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   818
			$taxonomy = 'post_tag';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   819
			$wpdb->insert( $wpdb->term_taxonomy, compact('term_id', 'taxonomy', 'description', 'parent', 'count') );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   820
			$tt_ids[$term_id][$taxonomy] = (int) $wpdb->insert_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   821
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   822
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   823
		if ( empty($count) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   824
			$count = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   825
			$taxonomy = 'category';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   826
			$wpdb->insert( $wpdb->term_taxonomy, compact('term_id', 'taxonomy', 'description', 'parent', 'count') );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   827
			$tt_ids[$term_id][$taxonomy] = (int) $wpdb->insert_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   828
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   829
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   830
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   831
	$select = 'post_id, category_id';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   832
	if ( $have_tags )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   833
		$select .= ', rel_type';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   834
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   835
	$posts = $wpdb->get_results("SELECT $select FROM $wpdb->post2cat GROUP BY post_id, category_id");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   836
	foreach ( $posts as $post ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   837
		$post_id = (int) $post->post_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   838
		$term_id = (int) $post->category_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   839
		$taxonomy = 'category';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   840
		if ( !empty($post->rel_type) && 'tag' == $post->rel_type)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   841
			$taxonomy = 'tag';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   842
		$tt_id = $tt_ids[$term_id][$taxonomy];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   843
		if ( empty($tt_id) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   844
			continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   845
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   846
		$wpdb->insert( $wpdb->term_relationships, array('object_id' => $post_id, 'term_taxonomy_id' => $tt_id) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   847
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   848
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   849
	// < 3570 we used linkcategories. >= 3570 we used categories and link2cat.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   850
	if ( $wp_current_db_version < 3570 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   851
		// Create link_category terms for link categories. Create a map of link cat IDs
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   852
		// to link_category terms.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   853
		$link_cat_id_map = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   854
		$default_link_cat = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   855
		$tt_ids = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   856
		$link_cats = $wpdb->get_results("SELECT cat_id, cat_name FROM " . $wpdb->prefix . 'linkcategories');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   857
		foreach ( $link_cats as $category) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   858
			$cat_id = (int) $category->cat_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   859
			$term_id = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   860
			$name = wp_slash($category->cat_name);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   861
			$slug = sanitize_title($name);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   862
			$term_group = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   863
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   864
			// Associate terms with the same slug in a term group and make slugs unique.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   865
			if ( $exists = $wpdb->get_results( $wpdb->prepare("SELECT term_id, term_group FROM $wpdb->terms WHERE slug = %s", $slug) ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   866
				$term_group = $exists[0]->term_group;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   867
				$term_id = $exists[0]->term_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   868
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   869
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   870
			if ( empty($term_id) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   871
				$wpdb->insert( $wpdb->terms, compact('name', 'slug', 'term_group') );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   872
				$term_id = (int) $wpdb->insert_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   873
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   874
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   875
			$link_cat_id_map[$cat_id] = $term_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   876
			$default_link_cat = $term_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   877
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   878
			$wpdb->insert( $wpdb->term_taxonomy, array('term_id' => $term_id, 'taxonomy' => 'link_category', 'description' => '', 'parent' => 0, 'count' => 0) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   879
			$tt_ids[$term_id] = (int) $wpdb->insert_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   880
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   881
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   882
		// Associate links to cats.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   883
		$links = $wpdb->get_results("SELECT link_id, link_category FROM $wpdb->links");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   884
		if ( !empty($links) ) foreach ( $links as $link ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   885
			if ( 0 == $link->link_category )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   886
				continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   887
			if ( ! isset($link_cat_id_map[$link->link_category]) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   888
				continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   889
			$term_id = $link_cat_id_map[$link->link_category];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   890
			$tt_id = $tt_ids[$term_id];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   891
			if ( empty($tt_id) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   892
				continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   893
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   894
			$wpdb->insert( $wpdb->term_relationships, array('object_id' => $link->link_id, 'term_taxonomy_id' => $tt_id) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   895
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   896
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   897
		// Set default to the last category we grabbed during the upgrade loop.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   898
		update_option('default_link_category', $default_link_cat);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   899
	} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   900
		$links = $wpdb->get_results("SELECT link_id, category_id FROM $wpdb->link2cat GROUP BY link_id, category_id");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   901
		foreach ( $links as $link ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   902
			$link_id = (int) $link->link_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   903
			$term_id = (int) $link->category_id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   904
			$taxonomy = 'link_category';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   905
			$tt_id = $tt_ids[$term_id][$taxonomy];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   906
			if ( empty($tt_id) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   907
				continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   908
			$wpdb->insert( $wpdb->term_relationships, array('object_id' => $link_id, 'term_taxonomy_id' => $tt_id) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   909
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   910
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   911
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   912
	if ( $wp_current_db_version < 4772 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   913
		// Obsolete linkcategories table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   914
		$wpdb->query('DROP TABLE IF EXISTS ' . $wpdb->prefix . 'linkcategories');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   915
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   916
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   917
	// Recalculate all counts
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   918
	$terms = $wpdb->get_results("SELECT term_taxonomy_id, taxonomy FROM $wpdb->term_taxonomy");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   919
	foreach ( (array) $terms as $term ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   920
		if ( ('post_tag' == $term->taxonomy) || ('category' == $term->taxonomy) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   921
			$count = $wpdb->get_var( $wpdb->prepare("SELECT COUNT(*) FROM $wpdb->term_relationships, $wpdb->posts WHERE $wpdb->posts.ID = $wpdb->term_relationships.object_id AND post_status = 'publish' AND post_type = 'post' AND term_taxonomy_id = %d", $term->term_taxonomy_id) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   922
		else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   923
			$count = $wpdb->get_var( $wpdb->prepare("SELECT COUNT(*) FROM $wpdb->term_relationships WHERE term_taxonomy_id = %d", $term->term_taxonomy_id) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   924
		$wpdb->update( $wpdb->term_taxonomy, array('count' => $count), array('term_taxonomy_id' => $term->term_taxonomy_id) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   925
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   926
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   927
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   928
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   929
 * Remove old options from the database.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   930
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   931
 * @since 2.3.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   932
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   933
function upgrade_230_options_table() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   934
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   935
	$old_options_fields = array( 'option_can_override', 'option_type', 'option_width', 'option_height', 'option_description', 'option_admin_level' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   936
	$wpdb->hide_errors();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   937
	foreach ( $old_options_fields as $old )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   938
		$wpdb->query("ALTER TABLE $wpdb->options DROP $old");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   939
	$wpdb->show_errors();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   940
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   941
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   942
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   943
 * Remove old categories, link2cat, and post2cat database tables.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   944
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   945
 * @since 2.3.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   946
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   947
function upgrade_230_old_tables() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   948
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   949
	$wpdb->query('DROP TABLE IF EXISTS ' . $wpdb->prefix . 'categories');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   950
	$wpdb->query('DROP TABLE IF EXISTS ' . $wpdb->prefix . 'link2cat');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   951
	$wpdb->query('DROP TABLE IF EXISTS ' . $wpdb->prefix . 'post2cat');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   952
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   953
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   954
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   955
 * Upgrade old slugs made in version 2.2.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   956
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   957
 * @since 2.2.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   958
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   959
function upgrade_old_slugs() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   960
	// upgrade people who were using the Redirect Old Slugs plugin
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   961
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   962
	$wpdb->query("UPDATE $wpdb->postmeta SET meta_key = '_wp_old_slug' WHERE meta_key = 'old_slug'");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   963
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   964
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   965
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   966
 * Execute changes made in WordPress 2.5.0.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   967
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   968
 * @since 2.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   969
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   970
function upgrade_250() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   971
	global $wp_current_db_version;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   972
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   973
	if ( $wp_current_db_version < 6689 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   974
		populate_roles_250();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   975
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   976
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   977
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   978
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   979
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   980
 * Execute changes made in WordPress 2.5.2.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   981
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   982
 * @since 2.5.2
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   983
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   984
function upgrade_252() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   985
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   986
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   987
	$wpdb->query("UPDATE $wpdb->users SET user_activation_key = ''");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   988
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   989
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   990
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   991
 * Execute changes made in WordPress 2.6.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   992
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   993
 * @since 2.6.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   994
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   995
function upgrade_260() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   996
	global $wp_current_db_version;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   997
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   998
	if ( $wp_current_db_version < 8000 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   999
		populate_roles_260();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1000
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1001
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1002
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1003
 * Execute changes made in WordPress 2.7.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1004
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1005
 * @since 2.7.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1006
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1007
function upgrade_270() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1008
	global $wpdb, $wp_current_db_version;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1009
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1010
	if ( $wp_current_db_version < 8980 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1011
		populate_roles_270();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1012
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1013
	// Update post_date for unpublished posts with empty timestamp
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1014
	if ( $wp_current_db_version < 8921 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1015
		$wpdb->query( "UPDATE $wpdb->posts SET post_date = post_modified WHERE post_date = '0000-00-00 00:00:00'" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1016
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1017
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1018
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1019
 * Execute changes made in WordPress 2.8.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1020
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1021
 * @since 2.8.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1022
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1023
function upgrade_280() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1024
	global $wp_current_db_version, $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1025
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1026
	if ( $wp_current_db_version < 10360 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1027
		populate_roles_280();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1028
	if ( is_multisite() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1029
		$start = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1030
		while( $rows = $wpdb->get_results( "SELECT option_name, option_value FROM $wpdb->options ORDER BY option_id LIMIT $start, 20" ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1031
			foreach( $rows as $row ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1032
				$value = $row->option_value;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1033
				if ( !@unserialize( $value ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1034
					$value = stripslashes( $value );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1035
				if ( $value !== $row->option_value ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1036
					update_option( $row->option_name, $value );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1037
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1038
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1039
			$start += 20;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1040
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1041
		refresh_blog_details( $wpdb->blogid );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1042
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1043
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1044
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1045
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1046
 * Execute changes made in WordPress 2.9.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1047
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1048
 * @since 2.9.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1049
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1050
function upgrade_290() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1051
	global $wp_current_db_version;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1052
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1053
	if ( $wp_current_db_version < 11958 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1054
		// Previously, setting depth to 1 would redundantly disable threading, but now 2 is the minimum depth to avoid confusion
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1055
		if ( get_option( 'thread_comments_depth' ) == '1' ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1056
			update_option( 'thread_comments_depth', 2 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1057
			update_option( 'thread_comments', 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1058
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1059
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1060
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1061
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1062
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1063
 * Execute changes made in WordPress 3.0.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1064
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1065
 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1066
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1067
function upgrade_300() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1068
	global $wp_current_db_version, $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1069
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1070
	if ( $wp_current_db_version < 15093 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1071
		populate_roles_300();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1072
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1073
	if ( $wp_current_db_version < 14139 && is_multisite() && is_main_site() && ! defined( 'MULTISITE' ) && get_site_option( 'siteurl' ) === false )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1074
		add_site_option( 'siteurl', '' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1075
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1076
	// 3.0 screen options key name changes.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1077
	if ( is_main_site() && !defined('DO_NOT_UPGRADE_GLOBAL_TABLES') ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1078
		$prefix = like_escape($wpdb->base_prefix);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1079
		$wpdb->query( "DELETE FROM $wpdb->usermeta WHERE meta_key LIKE '{$prefix}%meta-box-hidden%' OR meta_key LIKE '{$prefix}%closedpostboxes%' OR meta_key LIKE '{$prefix}%manage-%-columns-hidden%' OR meta_key LIKE '{$prefix}%meta-box-order%' OR meta_key LIKE '{$prefix}%metaboxorder%' OR meta_key LIKE '{$prefix}%screen_layout%'
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1080
					 OR meta_key = 'manageedittagscolumnshidden' OR meta_key='managecategoriescolumnshidden' OR meta_key = 'manageedit-tagscolumnshidden' OR meta_key = 'manageeditcolumnshidden' OR meta_key = 'categories_per_page' OR meta_key = 'edit_tags_per_page'" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1081
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1082
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1083
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1084
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1085
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1086
 * Execute changes made in WordPress 3.3.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1087
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1088
 * @since 3.3.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1089
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1090
function upgrade_330() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1091
	global $wp_current_db_version, $wpdb, $wp_registered_widgets, $sidebars_widgets;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1092
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1093
	if ( $wp_current_db_version < 19061 && is_main_site() && ! defined( 'DO_NOT_UPGRADE_GLOBAL_TABLES' ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1094
		$wpdb->query( "DELETE FROM $wpdb->usermeta WHERE meta_key IN ('show_admin_bar_admin', 'plugins_last_view')" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1095
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1096
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1097
	if ( $wp_current_db_version >= 11548 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1098
		return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1099
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1100
	$sidebars_widgets = get_option( 'sidebars_widgets', array() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1101
	$_sidebars_widgets = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1102
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1103
	if ( isset($sidebars_widgets['wp_inactive_widgets']) || empty($sidebars_widgets) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1104
		$sidebars_widgets['array_version'] = 3;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1105
	elseif ( !isset($sidebars_widgets['array_version']) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1106
		$sidebars_widgets['array_version'] = 1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1107
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1108
	switch ( $sidebars_widgets['array_version'] ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1109
		case 1 :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1110
			foreach ( (array) $sidebars_widgets as $index => $sidebar )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1111
			if ( is_array($sidebar) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1112
			foreach ( (array) $sidebar as $i => $name ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1113
				$id = strtolower($name);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1114
				if ( isset($wp_registered_widgets[$id]) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1115
					$_sidebars_widgets[$index][$i] = $id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1116
					continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1117
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1118
				$id = sanitize_title($name);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1119
				if ( isset($wp_registered_widgets[$id]) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1120
					$_sidebars_widgets[$index][$i] = $id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1121
					continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1122
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1123
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1124
				$found = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1125
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1126
				foreach ( $wp_registered_widgets as $widget_id => $widget ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1127
					if ( strtolower($widget['name']) == strtolower($name) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1128
						$_sidebars_widgets[$index][$i] = $widget['id'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1129
						$found = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1130
						break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1131
					} elseif ( sanitize_title($widget['name']) == sanitize_title($name) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1132
						$_sidebars_widgets[$index][$i] = $widget['id'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1133
						$found = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1134
						break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1135
					}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1136
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1137
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1138
				if ( $found )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1139
					continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1140
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1141
				unset($_sidebars_widgets[$index][$i]);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1142
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1143
			$_sidebars_widgets['array_version'] = 2;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1144
			$sidebars_widgets = $_sidebars_widgets;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1145
			unset($_sidebars_widgets);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1146
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1147
		case 2 :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1148
			$sidebars_widgets = retrieve_widgets();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1149
			$sidebars_widgets['array_version'] = 3;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1150
			update_option( 'sidebars_widgets', $sidebars_widgets );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1151
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1152
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1153
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1154
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1155
 * Execute changes made in WordPress 3.4.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1156
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1157
 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1158
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1159
function upgrade_340() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1160
	global $wp_current_db_version, $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1161
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1162
	if ( $wp_current_db_version < 19798 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1163
		$wpdb->hide_errors();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1164
		$wpdb->query( "ALTER TABLE $wpdb->options DROP COLUMN blog_id" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1165
		$wpdb->show_errors();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1166
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1167
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1168
	if ( $wp_current_db_version < 19799 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1169
		$wpdb->hide_errors();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1170
		$wpdb->query("ALTER TABLE $wpdb->comments DROP INDEX comment_approved");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1171
		$wpdb->show_errors();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1172
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1173
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1174
	if ( $wp_current_db_version < 20022 && is_main_site() && ! defined( 'DO_NOT_UPGRADE_GLOBAL_TABLES' ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1175
		$wpdb->query( "DELETE FROM $wpdb->usermeta WHERE meta_key = 'themes_last_view'" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1176
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1177
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1178
	if ( $wp_current_db_version < 20080 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1179
		if ( 'yes' == $wpdb->get_var( "SELECT autoload FROM $wpdb->options WHERE option_name = 'uninstall_plugins'" ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1180
			$uninstall_plugins = get_option( 'uninstall_plugins' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1181
			delete_option( 'uninstall_plugins' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1182
			add_option( 'uninstall_plugins', $uninstall_plugins, null, 'no' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1183
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1184
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1185
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1186
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1187
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1188
 * Execute changes made in WordPress 3.5.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1189
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1190
 * @since 3.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1191
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1192
function upgrade_350() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1193
	global $wp_current_db_version, $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1194
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1195
	if ( $wp_current_db_version < 22006 && $wpdb->get_var( "SELECT link_id FROM $wpdb->links LIMIT 1" ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1196
		update_option( 'link_manager_enabled', 1 ); // Previously set to 0 by populate_options()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1197
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1198
	if ( $wp_current_db_version < 21811 && is_main_site() && ! defined( 'DO_NOT_UPGRADE_GLOBAL_TABLES' ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1199
		$meta_keys = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1200
		foreach ( array_merge( get_post_types(), get_taxonomies() ) as $name ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1201
			if ( false !== strpos( $name, '-' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1202
			$meta_keys[] = 'edit_' . str_replace( '-', '_', $name ) . '_per_page';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1203
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1204
		if ( $meta_keys ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1205
			$meta_keys = implode( "', '", $meta_keys );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1206
			$wpdb->query( "DELETE FROM $wpdb->usermeta WHERE meta_key IN ('$meta_keys')" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1207
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1208
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1209
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1210
	if ( $wp_current_db_version < 22422 && $term = get_term_by( 'slug', 'post-format-standard', 'post_format' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1211
		wp_delete_term( $term->term_id, 'post_format' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1212
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1213
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1214
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1215
 * Execute changes made in WordPress 3.7.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1216
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1217
 * @since 3.7.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1218
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1219
function upgrade_370() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1220
	global $wp_current_db_version;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1221
	if ( $wp_current_db_version < 25824 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1222
		wp_clear_scheduled_hook( 'wp_auto_updates_maybe_update' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1223
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1224
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1225
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1226
 * Execute network level changes
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1227
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1228
 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1229
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1230
function upgrade_network() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1231
	global $wp_current_db_version, $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1232
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1233
	// Always
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1234
	if ( is_main_network() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1235
		// Deletes all expired transients.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1236
		// The multi-table delete syntax is used to delete the transient record from table a,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1237
		// and the corresponding transient_timeout record from table b.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1238
		$time = time();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1239
		$wpdb->query("DELETE a, b FROM $wpdb->sitemeta a, $wpdb->sitemeta b WHERE
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1240
			a.meta_key LIKE '\_site\_transient\_%' AND
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1241
			a.meta_key NOT LIKE '\_site\_transient\_timeout\_%' AND
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1242
			b.meta_key = CONCAT( '_site_transient_timeout_', SUBSTRING( a.meta_key, 17 ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1243
			AND b.meta_value < $time");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1244
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1245
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1246
	// 2.8
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1247
	if ( $wp_current_db_version < 11549 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1248
		$wpmu_sitewide_plugins = get_site_option( 'wpmu_sitewide_plugins' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1249
		$active_sitewide_plugins = get_site_option( 'active_sitewide_plugins' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1250
		if ( $wpmu_sitewide_plugins ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1251
			if ( !$active_sitewide_plugins )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1252
				$sitewide_plugins = (array) $wpmu_sitewide_plugins;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1253
			else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1254
				$sitewide_plugins = array_merge( (array) $active_sitewide_plugins, (array) $wpmu_sitewide_plugins );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1255
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1256
			update_site_option( 'active_sitewide_plugins', $sitewide_plugins );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1257
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1258
		delete_site_option( 'wpmu_sitewide_plugins' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1259
		delete_site_option( 'deactivated_sitewide_plugins' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1260
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1261
		$start = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1262
		while( $rows = $wpdb->get_results( "SELECT meta_key, meta_value FROM {$wpdb->sitemeta} ORDER BY meta_id LIMIT $start, 20" ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1263
			foreach( $rows as $row ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1264
				$value = $row->meta_value;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1265
				if ( !@unserialize( $value ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1266
					$value = stripslashes( $value );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1267
				if ( $value !== $row->meta_value ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1268
					update_site_option( $row->meta_key, $value );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1269
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1270
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1271
			$start += 20;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1272
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1273
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1274
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1275
	// 3.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1276
	if ( $wp_current_db_version < 13576 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1277
		update_site_option( 'global_terms_enabled', '1' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1278
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1279
	// 3.3
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1280
	if ( $wp_current_db_version < 19390 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1281
		update_site_option( 'initial_db_version', $wp_current_db_version );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1282
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1283
	if ( $wp_current_db_version < 19470 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1284
		if ( false === get_site_option( 'active_sitewide_plugins' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1285
			update_site_option( 'active_sitewide_plugins', array() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1286
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1287
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1288
	// 3.4
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1289
	if ( $wp_current_db_version < 20148 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1290
		// 'allowedthemes' keys things by stylesheet. 'allowed_themes' keyed things by name.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1291
		$allowedthemes  = get_site_option( 'allowedthemes'  );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1292
		$allowed_themes = get_site_option( 'allowed_themes' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1293
		if ( false === $allowedthemes && is_array( $allowed_themes ) && $allowed_themes ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1294
			$converted = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1295
			$themes = wp_get_themes();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1296
			foreach ( $themes as $stylesheet => $theme_data ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1297
				if ( isset( $allowed_themes[ $theme_data->get('Name') ] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1298
					$converted[ $stylesheet ] = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1299
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1300
			update_site_option( 'allowedthemes', $converted );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1301
			delete_site_option( 'allowed_themes' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1302
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1303
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1304
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1305
	// 3.5
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1306
	if ( $wp_current_db_version < 21823 )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1307
		update_site_option( 'ms_files_rewriting', '1' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1308
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1309
	// 3.5.2
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1310
	if ( $wp_current_db_version < 24448 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1311
		$illegal_names = get_site_option( 'illegal_names' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1312
		if ( is_array( $illegal_names ) && count( $illegal_names ) === 1 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1313
			$illegal_name = reset( $illegal_names );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1314
			$illegal_names = explode( ' ', $illegal_name );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1315
			update_site_option( 'illegal_names', $illegal_names );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1316
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1317
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1318
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1319
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1320
// The functions we use to actually do stuff
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1321
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1322
// General
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1323
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1324
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1325
 * {@internal Missing Short Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1326
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1327
 * {@internal Missing Long Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1328
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1329
 * @since 1.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1330
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1331
 * @param string $table_name Database table name to create.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1332
 * @param string $create_ddl SQL statement to create table.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1333
 * @return bool If table already exists or was created by function.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1334
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1335
function maybe_create_table($table_name, $create_ddl) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1336
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1337
	if ( $wpdb->get_var("SHOW TABLES LIKE '$table_name'") == $table_name )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1338
		return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1339
	//didn't find it try to create it.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1340
	$q = $wpdb->query($create_ddl);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1341
	// we cannot directly tell that whether this succeeded!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1342
	if ( $wpdb->get_var("SHOW TABLES LIKE '$table_name'") == $table_name )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1343
		return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1344
	return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1345
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1346
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1347
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1348
 * {@internal Missing Short Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1349
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1350
 * {@internal Missing Long Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1351
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1352
 * @since 1.0.1
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1353
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1354
 * @param string $table Database table name.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1355
 * @param string $index Index name to drop.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1356
 * @return bool True, when finished.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1357
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1358
function drop_index($table, $index) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1359
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1360
	$wpdb->hide_errors();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1361
	$wpdb->query("ALTER TABLE `$table` DROP INDEX `$index`");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1362
	// Now we need to take out all the extra ones we may have created
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1363
	for ($i = 0; $i < 25; $i++) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1364
		$wpdb->query("ALTER TABLE `$table` DROP INDEX `{$index}_$i`");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1365
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1366
	$wpdb->show_errors();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1367
	return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1368
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1369
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1370
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1371
 * {@internal Missing Short Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1372
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1373
 * {@internal Missing Long Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1374
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1375
 * @since 1.0.1
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1376
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1377
 * @param string $table Database table name.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1378
 * @param string $index Database table index column.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1379
 * @return bool True, when done with execution.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1380
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1381
function add_clean_index($table, $index) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1382
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1383
	drop_index($table, $index);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1384
	$wpdb->query("ALTER TABLE `$table` ADD INDEX ( `$index` )");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1385
	return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1386
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1387
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1388
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1389
 ** maybe_add_column()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1390
 ** Add column to db table if it doesn't exist.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1391
 ** Returns:  true if already exists or on successful completion
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1392
 **           false on error
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1393
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1394
function maybe_add_column($table_name, $column_name, $create_ddl) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1395
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1396
	foreach ($wpdb->get_col("DESC $table_name", 0) as $column ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1397
		if ($column == $column_name) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1398
			return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1399
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1400
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1401
	//didn't find it try to create it.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1402
	$q = $wpdb->query($create_ddl);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1403
	// we cannot directly tell that whether this succeeded!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1404
	foreach ($wpdb->get_col("DESC $table_name", 0) as $column ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1405
		if ($column == $column_name) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1406
			return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1407
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1408
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1409
	return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1410
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1411
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1412
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1413
 * Retrieve all options as it was for 1.2.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1414
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1415
 * @since 1.2.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1416
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1417
 * @return array List of options.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1418
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1419
function get_alloptions_110() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1420
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1421
	$all_options = new stdClass;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1422
	if ( $options = $wpdb->get_results( "SELECT option_name, option_value FROM $wpdb->options" ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1423
		foreach ( $options as $option ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1424
			if ( 'siteurl' == $option->option_name || 'home' == $option->option_name || 'category_base' == $option->option_name )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1425
				$option->option_value = untrailingslashit( $option->option_value );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1426
			$all_options->{$option->option_name} = stripslashes( $option->option_value );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1427
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1428
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1429
	return $all_options;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1430
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1431
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1432
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1433
 * Version of get_option that is private to install/upgrade.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1434
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1435
 * @since 1.5.1
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1436
 * @access private
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1437
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1438
 * @param string $setting Option name.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1439
 * @return mixed
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1440
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1441
function __get_option($setting) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1442
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1443
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1444
	if ( $setting == 'home' && defined( 'WP_HOME' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1445
		return untrailingslashit( WP_HOME );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1446
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1447
	if ( $setting == 'siteurl' && defined( 'WP_SITEURL' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1448
		return untrailingslashit( WP_SITEURL );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1449
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1450
	$option = $wpdb->get_var( $wpdb->prepare("SELECT option_value FROM $wpdb->options WHERE option_name = %s", $setting ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1451
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1452
	if ( 'home' == $setting && '' == $option )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1453
		return __get_option( 'siteurl' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1454
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1455
	if ( 'siteurl' == $setting || 'home' == $setting || 'category_base' == $setting || 'tag_base' == $setting )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1456
		$option = untrailingslashit( $option );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1457
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1458
	return maybe_unserialize( $option );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1459
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1460
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1461
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1462
 * {@internal Missing Short Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1463
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1464
 * {@internal Missing Long Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1465
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1466
 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1467
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1468
 * @param string $content
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1469
 * @return string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1470
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1471
function deslash($content) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1472
	// Note: \\\ inside a regex denotes a single backslash.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1473
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1474
	// Replace one or more backslashes followed by a single quote with
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1475
	// a single quote.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1476
	$content = preg_replace("/\\\+'/", "'", $content);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1477
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1478
	// Replace one or more backslashes followed by a double quote with
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1479
	// a double quote.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1480
	$content = preg_replace('/\\\+"/', '"', $content);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1481
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1482
	// Replace one or more backslashes with one backslash.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1483
	$content = preg_replace("/\\\+/", "\\", $content);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1484
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1485
	return $content;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1486
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1487
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1488
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1489
 * {@internal Missing Short Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1490
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1491
 * {@internal Missing Long Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1492
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1493
 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1494
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1495
 * @param unknown_type $queries
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1496
 * @param unknown_type $execute
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1497
 * @return unknown
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1498
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1499
function dbDelta( $queries = '', $execute = true ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1500
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1501
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1502
	if ( in_array( $queries, array( '', 'all', 'blog', 'global', 'ms_global' ), true ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1503
	    $queries = wp_get_db_schema( $queries );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1504
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1505
	// Separate individual queries into an array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1506
	if ( !is_array($queries) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1507
		$queries = explode( ';', $queries );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1508
		$queries = array_filter( $queries );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1509
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1510
	$queries = apply_filters( 'dbdelta_queries', $queries );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1511
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1512
	$cqueries = array(); // Creation Queries
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1513
	$iqueries = array(); // Insertion Queries
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1514
	$for_update = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1515
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1516
	// Create a tablename index for an array ($cqueries) of queries
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1517
	foreach($queries as $qry) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1518
		if (preg_match("|CREATE TABLE ([^ ]*)|", $qry, $matches)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1519
			$cqueries[ trim( $matches[1], '`' ) ] = $qry;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1520
			$for_update[$matches[1]] = 'Created table '.$matches[1];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1521
		} else if (preg_match("|CREATE DATABASE ([^ ]*)|", $qry, $matches)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1522
			array_unshift($cqueries, $qry);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1523
		} else if (preg_match("|INSERT INTO ([^ ]*)|", $qry, $matches)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1524
			$iqueries[] = $qry;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1525
		} else if (preg_match("|UPDATE ([^ ]*)|", $qry, $matches)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1526
			$iqueries[] = $qry;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1527
		} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1528
			// Unrecognized query type
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1529
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1530
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1531
	$cqueries = apply_filters( 'dbdelta_create_queries', $cqueries );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1532
	$iqueries = apply_filters( 'dbdelta_insert_queries', $iqueries );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1533
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1534
	$global_tables = $wpdb->tables( 'global' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1535
	foreach ( $cqueries as $table => $qry ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1536
		// Upgrade global tables only for the main site. Don't upgrade at all if DO_NOT_UPGRADE_GLOBAL_TABLES is defined.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1537
		if ( in_array( $table, $global_tables ) && ( !is_main_site() || defined( 'DO_NOT_UPGRADE_GLOBAL_TABLES' ) ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1538
			continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1539
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1540
		// Fetch the table column structure from the database
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1541
		$wpdb->suppress_errors();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1542
		$tablefields = $wpdb->get_results("DESCRIBE {$table};");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1543
		$wpdb->suppress_errors( false );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1544
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1545
		if ( ! $tablefields )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1546
			continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1547
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1548
		// Clear the field and index arrays
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1549
		$cfields = $indices = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1550
		// Get all of the field names in the query from between the parens
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1551
		preg_match("|\((.*)\)|ms", $qry, $match2);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1552
		$qryline = trim($match2[1]);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1553
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1554
		// Separate field lines into an array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1555
		$flds = explode("\n", $qryline);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1556
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1557
		//echo "<hr/><pre>\n".print_r(strtolower($table), true).":\n".print_r($cqueries, true)."</pre><hr/>";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1558
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1559
		// For every field line specified in the query
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1560
		foreach ($flds as $fld) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1561
			// Extract the field name
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1562
			preg_match("|^([^ ]*)|", trim($fld), $fvals);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1563
			$fieldname = trim( $fvals[1], '`' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1564
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1565
			// Verify the found field name
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1566
			$validfield = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1567
			switch (strtolower($fieldname)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1568
			case '':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1569
			case 'primary':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1570
			case 'index':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1571
			case 'fulltext':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1572
			case 'unique':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1573
			case 'key':
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1574
				$validfield = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1575
				$indices[] = trim(trim($fld), ", \n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1576
				break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1577
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1578
			$fld = trim($fld);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1579
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1580
			// If it's a valid field, add it to the field array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1581
			if ($validfield) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1582
				$cfields[strtolower($fieldname)] = trim($fld, ", \n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1583
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1584
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1585
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1586
		// For every field in the table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1587
		foreach ($tablefields as $tablefield) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1588
			// If the table field exists in the field array...
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1589
			if (array_key_exists(strtolower($tablefield->Field), $cfields)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1590
				// Get the field type from the query
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1591
				preg_match("|".$tablefield->Field." ([^ ]*( unsigned)?)|i", $cfields[strtolower($tablefield->Field)], $matches);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1592
				$fieldtype = $matches[1];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1593
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1594
				// Is actual field type different from the field type in query?
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1595
				if ($tablefield->Type != $fieldtype) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1596
					// Add a query to change the column type
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1597
					$cqueries[] = "ALTER TABLE {$table} CHANGE COLUMN {$tablefield->Field} " . $cfields[strtolower($tablefield->Field)];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1598
					$for_update[$table.'.'.$tablefield->Field] = "Changed type of {$table}.{$tablefield->Field} from {$tablefield->Type} to {$fieldtype}";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1599
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1600
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1601
				// Get the default value from the array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1602
					//echo "{$cfields[strtolower($tablefield->Field)]}<br>";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1603
				if (preg_match("| DEFAULT '(.*?)'|i", $cfields[strtolower($tablefield->Field)], $matches)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1604
					$default_value = $matches[1];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1605
					if ($tablefield->Default != $default_value) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1606
						// Add a query to change the column's default value
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1607
						$cqueries[] = "ALTER TABLE {$table} ALTER COLUMN {$tablefield->Field} SET DEFAULT '{$default_value}'";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1608
						$for_update[$table.'.'.$tablefield->Field] = "Changed default value of {$table}.{$tablefield->Field} from {$tablefield->Default} to {$default_value}";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1609
					}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1610
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1611
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1612
				// Remove the field from the array (so it's not added)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1613
				unset($cfields[strtolower($tablefield->Field)]);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1614
			} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1615
				// This field exists in the table, but not in the creation queries?
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1616
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1617
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1618
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1619
		// For every remaining field specified for the table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1620
		foreach ($cfields as $fieldname => $fielddef) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1621
			// Push a query line into $cqueries that adds the field to that table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1622
			$cqueries[] = "ALTER TABLE {$table} ADD COLUMN $fielddef";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1623
			$for_update[$table.'.'.$fieldname] = 'Added column '.$table.'.'.$fieldname;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1624
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1625
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1626
		// Index stuff goes here
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1627
		// Fetch the table index structure from the database
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1628
		$tableindices = $wpdb->get_results("SHOW INDEX FROM {$table};");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1629
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1630
		if ($tableindices) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1631
			// Clear the index array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1632
			unset($index_ary);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1633
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1634
			// For every index in the table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1635
			foreach ($tableindices as $tableindex) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1636
				// Add the index to the index data array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1637
				$keyname = $tableindex->Key_name;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1638
				$index_ary[$keyname]['columns'][] = array('fieldname' => $tableindex->Column_name, 'subpart' => $tableindex->Sub_part);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1639
				$index_ary[$keyname]['unique'] = ($tableindex->Non_unique == 0)?true:false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1640
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1641
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1642
			// For each actual index in the index array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1643
			foreach ($index_ary as $index_name => $index_data) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1644
				// Build a create string to compare to the query
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1645
				$index_string = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1646
				if ($index_name == 'PRIMARY') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1647
					$index_string .= 'PRIMARY ';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1648
				} else if($index_data['unique']) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1649
					$index_string .= 'UNIQUE ';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1650
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1651
				$index_string .= 'KEY ';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1652
				if ($index_name != 'PRIMARY') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1653
					$index_string .= $index_name;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1654
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1655
				$index_columns = '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1656
				// For each column in the index
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1657
				foreach ($index_data['columns'] as $column_data) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1658
					if ($index_columns != '') $index_columns .= ',';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1659
					// Add the field to the column list string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1660
					$index_columns .= $column_data['fieldname'];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1661
					if ($column_data['subpart'] != '') {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1662
						$index_columns .= '('.$column_data['subpart'].')';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1663
					}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1664
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1665
				// Add the column list to the index create string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1666
				$index_string .= ' ('.$index_columns.')';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1667
				if (!(($aindex = array_search($index_string, $indices)) === false)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1668
					unset($indices[$aindex]);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1669
					//echo "<pre style=\"border:1px solid #ccc;margin-top:5px;\">{$table}:<br />Found index:".$index_string."</pre>\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1670
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1671
				//else echo "<pre style=\"border:1px solid #ccc;margin-top:5px;\">{$table}:<br /><b>Did not find index:</b>".$index_string."<br />".print_r($indices, true)."</pre>\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1672
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1673
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1674
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1675
		// For every remaining index specified for the table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1676
		foreach ( (array) $indices as $index ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1677
			// Push a query line into $cqueries that adds the index to that table
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1678
			$cqueries[] = "ALTER TABLE {$table} ADD $index";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1679
			$for_update[] = 'Added index ' . $table . ' ' . $index;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1680
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1681
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1682
		// Remove the original table creation query from processing
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1683
		unset( $cqueries[ $table ], $for_update[ $table ] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1684
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1685
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1686
	$allqueries = array_merge($cqueries, $iqueries);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1687
	if ($execute) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1688
		foreach ($allqueries as $query) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1689
			//echo "<pre style=\"border:1px solid #ccc;margin-top:5px;\">".print_r($query, true)."</pre>\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1690
			$wpdb->query($query);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1691
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1692
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1693
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1694
	return $for_update;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1695
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1696
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1697
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1698
 * {@internal Missing Short Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1699
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1700
 * {@internal Missing Long Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1701
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1702
 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1703
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1704
function make_db_current( $tables = 'all' ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1705
	$alterations = dbDelta( $tables );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1706
	echo "<ol>\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1707
	foreach($alterations as $alteration) echo "<li>$alteration</li>\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1708
	echo "</ol>\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1709
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1710
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1711
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1712
 * {@internal Missing Short Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1713
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1714
 * {@internal Missing Long Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1715
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1716
 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1717
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1718
function make_db_current_silent( $tables = 'all' ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1719
	$alterations = dbDelta( $tables );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1720
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1721
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1722
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1723
 * {@internal Missing Short Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1724
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1725
 * {@internal Missing Long Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1726
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1727
 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1728
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1729
 * @param unknown_type $theme_name
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1730
 * @param unknown_type $template
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1731
 * @return unknown
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1732
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1733
function make_site_theme_from_oldschool($theme_name, $template) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1734
	$home_path = get_home_path();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1735
	$site_dir = WP_CONTENT_DIR . "/themes/$template";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1736
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1737
	if (! file_exists("$home_path/index.php"))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1738
		return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1739
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1740
	// Copy files from the old locations to the site theme.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1741
	// TODO: This does not copy arbitrary include dependencies. Only the
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1742
	// standard WP files are copied.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1743
	$files = array('index.php' => 'index.php', 'wp-layout.css' => 'style.css', 'wp-comments.php' => 'comments.php', 'wp-comments-popup.php' => 'comments-popup.php');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1744
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1745
	foreach ($files as $oldfile => $newfile) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1746
		if ($oldfile == 'index.php')
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1747
			$oldpath = $home_path;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1748
		else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1749
			$oldpath = ABSPATH;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1750
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1751
		if ($oldfile == 'index.php') { // Check to make sure it's not a new index
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1752
			$index = implode('', file("$oldpath/$oldfile"));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1753
			if (strpos($index, 'WP_USE_THEMES') !== false) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1754
				if (! @copy(WP_CONTENT_DIR . '/themes/' . WP_DEFAULT_THEME . '/index.php', "$site_dir/$newfile"))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1755
					return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1756
				continue; // Don't copy anything
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1757
				}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1758
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1759
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1760
		if (! @copy("$oldpath/$oldfile", "$site_dir/$newfile"))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1761
			return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1762
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1763
		chmod("$site_dir/$newfile", 0777);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1764
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1765
		// Update the blog header include in each file.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1766
		$lines = explode("\n", implode('', file("$site_dir/$newfile")));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1767
		if ($lines) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1768
			$f = fopen("$site_dir/$newfile", 'w');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1769
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1770
			foreach ($lines as $line) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1771
				if (preg_match('/require.*wp-blog-header/', $line))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1772
					$line = '//' . $line;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1773
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1774
				// Update stylesheet references.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1775
				$line = str_replace("<?php echo __get_option('siteurl'); ?>/wp-layout.css", "<?php bloginfo('stylesheet_url'); ?>", $line);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1776
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1777
				// Update comments template inclusion.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1778
				$line = str_replace("<?php include(ABSPATH . 'wp-comments.php'); ?>", "<?php comments_template(); ?>", $line);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1779
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1780
				fwrite($f, "{$line}\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1781
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1782
			fclose($f);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1783
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1784
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1785
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1786
	// Add a theme header.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1787
	$header = "/*\nTheme Name: $theme_name\nTheme URI: " . __get_option('siteurl') . "\nDescription: A theme automatically created by the update.\nVersion: 1.0\nAuthor: Moi\n*/\n";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1788
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1789
	$stylelines = file_get_contents("$site_dir/style.css");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1790
	if ($stylelines) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1791
		$f = fopen("$site_dir/style.css", 'w');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1792
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1793
		fwrite($f, $header);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1794
		fwrite($f, $stylelines);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1795
		fclose($f);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1796
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1797
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1798
	return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1799
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1800
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1801
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1802
 * {@internal Missing Short Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1803
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1804
 * {@internal Missing Long Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1805
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1806
 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1807
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1808
 * @param unknown_type $theme_name
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1809
 * @param unknown_type $template
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1810
 * @return unknown
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1811
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1812
function make_site_theme_from_default($theme_name, $template) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1813
	$site_dir = WP_CONTENT_DIR . "/themes/$template";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1814
	$default_dir = WP_CONTENT_DIR . '/themes/' . WP_DEFAULT_THEME;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1815
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1816
	// Copy files from the default theme to the site theme.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1817
	//$files = array('index.php', 'comments.php', 'comments-popup.php', 'footer.php', 'header.php', 'sidebar.php', 'style.css');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1818
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1819
	$theme_dir = @ opendir($default_dir);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1820
	if ($theme_dir) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1821
		while(($theme_file = readdir( $theme_dir )) !== false) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1822
			if (is_dir("$default_dir/$theme_file"))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1823
				continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1824
			if (! @copy("$default_dir/$theme_file", "$site_dir/$theme_file"))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1825
				return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1826
			chmod("$site_dir/$theme_file", 0777);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1827
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1828
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1829
	@closedir($theme_dir);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1830
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1831
	// Rewrite the theme header.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1832
	$stylelines = explode("\n", implode('', file("$site_dir/style.css")));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1833
	if ($stylelines) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1834
		$f = fopen("$site_dir/style.css", 'w');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1835
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1836
		foreach ($stylelines as $line) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1837
			if (strpos($line, 'Theme Name:') !== false) $line = 'Theme Name: ' . $theme_name;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1838
			elseif (strpos($line, 'Theme URI:') !== false) $line = 'Theme URI: ' . __get_option('url');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1839
			elseif (strpos($line, 'Description:') !== false) $line = 'Description: Your theme.';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1840
			elseif (strpos($line, 'Version:') !== false) $line = 'Version: 1';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1841
			elseif (strpos($line, 'Author:') !== false) $line = 'Author: You';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1842
			fwrite($f, $line . "\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1843
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1844
		fclose($f);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1845
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1846
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1847
	// Copy the images.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1848
	umask(0);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1849
	if (! mkdir("$site_dir/images", 0777)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1850
		return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1851
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1852
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1853
	$images_dir = @ opendir("$default_dir/images");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1854
	if ($images_dir) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1855
		while(($image = readdir($images_dir)) !== false) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1856
			if (is_dir("$default_dir/images/$image"))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1857
				continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1858
			if (! @copy("$default_dir/images/$image", "$site_dir/images/$image"))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1859
				return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1860
			chmod("$site_dir/images/$image", 0777);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1861
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1862
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1863
	@closedir($images_dir);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1864
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1865
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1866
// Create a site theme from the default theme.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1867
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1868
 * {@internal Missing Short Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1869
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1870
 * {@internal Missing Long Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1871
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1872
 * @since 1.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1873
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1874
 * @return unknown
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1875
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1876
function make_site_theme() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1877
	// Name the theme after the blog.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1878
	$theme_name = __get_option('blogname');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1879
	$template = sanitize_title($theme_name);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1880
	$site_dir = WP_CONTENT_DIR . "/themes/$template";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1881
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1882
	// If the theme already exists, nothing to do.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1883
	if ( is_dir($site_dir)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1884
		return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1885
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1886
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1887
	// We must be able to write to the themes dir.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1888
	if (! is_writable(WP_CONTENT_DIR . "/themes")) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1889
		return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1890
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1891
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1892
	umask(0);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1893
	if (! mkdir($site_dir, 0777)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1894
		return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1895
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1896
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1897
	if (file_exists(ABSPATH . 'wp-layout.css')) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1898
		if (! make_site_theme_from_oldschool($theme_name, $template)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1899
			// TODO: rm -rf the site theme directory.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1900
			return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1901
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1902
	} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1903
		if (! make_site_theme_from_default($theme_name, $template))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1904
			// TODO: rm -rf the site theme directory.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1905
			return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1906
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1907
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1908
	// Make the new site theme active.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1909
	$current_template = __get_option('template');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1910
	if ($current_template == WP_DEFAULT_THEME) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1911
		update_option('template', $template);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1912
		update_option('stylesheet', $template);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1913
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1914
	return $template;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1915
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1916
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1917
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1918
 * Translate user level to user role name.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1919
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1920
 * @since 2.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1921
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1922
 * @param int $level User level.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1923
 * @return string User role name.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1924
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1925
function translate_level_to_role($level) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1926
	switch ($level) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1927
	case 10:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1928
	case 9:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1929
	case 8:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1930
		return 'administrator';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1931
	case 7:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1932
	case 6:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1933
	case 5:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1934
		return 'editor';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1935
	case 4:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1936
	case 3:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1937
	case 2:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1938
		return 'author';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1939
	case 1:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1940
		return 'contributor';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1941
	case 0:
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1942
		return 'subscriber';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1943
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1944
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1945
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1946
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1947
 * {@internal Missing Short Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1948
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1949
 * {@internal Missing Long Description}}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1950
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1951
 * @since 2.1.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1952
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1953
function wp_check_mysql_version() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1954
	global $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1955
	$result = $wpdb->check_database_version();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1956
	if ( is_wp_error( $result ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1957
		die( $result->get_error_message() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1958
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1959
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1960
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1961
 * Disables the Automattic widgets plugin, which was merged into core.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1962
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1963
 * @since 2.2.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1964
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1965
function maybe_disable_automattic_widgets() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1966
	$plugins = __get_option( 'active_plugins' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1967
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1968
	foreach ( (array) $plugins as $plugin ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1969
		if ( basename( $plugin ) == 'widgets.php' ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1970
			array_splice( $plugins, array_search( $plugin, $plugins ), 1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1971
			update_option( 'active_plugins', $plugins );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1972
			break;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1973
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1974
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1975
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1976
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1977
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1978
 * Disables the Link Manager on upgrade, if at the time of upgrade, no links exist in the DB.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1979
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1980
 * @since 3.5.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1981
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1982
function maybe_disable_link_manager() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1983
	global $wp_current_db_version, $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1984
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1985
	if ( $wp_current_db_version >= 22006 && get_option( 'link_manager_enabled' ) && ! $wpdb->get_var( "SELECT link_id FROM $wpdb->links LIMIT 1" ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1986
		update_option( 'link_manager_enabled', 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1987
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1988
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1989
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1990
 * Runs before the schema is upgraded.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1991
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1992
 * @since 2.9.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1993
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1994
function pre_schema_upgrade() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1995
	global $wp_current_db_version, $wp_db_version, $wpdb;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1996
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1997
	// Upgrade versions prior to 2.9
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1998
	if ( $wp_current_db_version < 11557 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1999
		// Delete duplicate options. Keep the option with the highest option_id.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2000
		$wpdb->query("DELETE o1 FROM $wpdb->options AS o1 JOIN $wpdb->options AS o2 USING (`option_name`) WHERE o2.option_id > o1.option_id");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2001
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2002
		// Drop the old primary key and add the new.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2003
		$wpdb->query("ALTER TABLE $wpdb->options DROP PRIMARY KEY, ADD PRIMARY KEY(option_id)");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2004
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2005
		// Drop the old option_name index. dbDelta() doesn't do the drop.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2006
		$wpdb->query("ALTER TABLE $wpdb->options DROP INDEX option_name");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2007
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2008
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2009
	// Multisite schema upgrades.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2010
	if ( $wp_current_db_version < 25448 && is_multisite() && ! defined( 'DO_NOT_UPGRADE_GLOBAL_TABLES' ) && is_main_network() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2011
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2012
		// Upgrade verions prior to 3.7
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2013
		if ( $wp_current_db_version < 25179 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2014
			// New primary key for signups.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2015
			$wpdb->query( "ALTER TABLE $wpdb->signups ADD signup_id BIGINT(20) NOT NULL AUTO_INCREMENT PRIMARY KEY FIRST" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2016
			$wpdb->query( "ALTER TABLE $wpdb->signups DROP INDEX domain" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2017
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2018
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2019
		if ( $wp_current_db_version < 25448 ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2020
			// Convert archived from enum to tinyint.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2021
			$wpdb->query( "ALTER TABLE $wpdb->blogs CHANGE COLUMN archived archived varchar(1) NOT NULL default '0'" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2022
			$wpdb->query( "ALTER TABLE $wpdb->blogs CHANGE COLUMN archived archived tinyint(2) NOT NULL default 0" );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2023
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2024
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2025
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2026
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2027
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2028
 * Install global terms.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2029
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2030
 * @since 3.0.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2031
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2032
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2033
if ( !function_exists( 'install_global_terms' ) ) :
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2034
function install_global_terms() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2035
	global $wpdb, $charset_collate;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2036
	$ms_queries = "
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2037
CREATE TABLE $wpdb->sitecategories (
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2038
  cat_ID bigint(20) NOT NULL auto_increment,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2039
  cat_name varchar(55) NOT NULL default '',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2040
  category_nicename varchar(200) NOT NULL default '',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2041
  last_updated timestamp NOT NULL,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2042
  PRIMARY KEY  (cat_ID),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2043
  KEY category_nicename (category_nicename),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2044
  KEY last_updated (last_updated)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2045
) $charset_collate;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2046
";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2047
// now create tables
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2048
	dbDelta( $ms_queries );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2049
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  2050
endif;