<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head><meta http-equiv="content-type" content="text/html; charset=utf-8" /><style type="text/css"><!--
#msg dl { border: 1px #006 solid; background: #369; padding: 6px; color: #fff; }
#msg dt { float: left; width: 6em; font-weight: bold; }
#msg dt:after { content:':';}
#msg dl, #msg dt, #msg ul, #msg li, #header, #footer { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt;  }
#msg dl a { font-weight: bold}
#msg dl a:link    { color:#fc3; }
#msg dl a:active  { color:#ff0; }
#msg dl a:visited { color:#cc6; }
h3 { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt; font-weight: bold; }
#msg pre { overflow: auto; background: #ffc; border: 1px #fc0 solid; padding: 6px; }
#msg ul, pre { overflow: auto; }
#header, #footer { color: #fff; background: #636; border: 1px #300 solid; padding: 6px; }
#patch { width: 100%; }
#patch h4 {font-family: verdana,arial,helvetica,sans-serif;font-size:10pt;padding:8px;background:#369;color:#fff;margin:0;}
#patch .propset h4, #patch .binary h4 {margin:0;}
#patch pre {padding:0;line-height:1.2em;margin:0;}
#patch .diff {width:100%;background:#eee;padding: 0 0 10px 0;overflow:auto;}
#patch .propset .diff, #patch .binary .diff  {padding:10px 0;}
#patch span {display:block;padding:0 10px;}
#patch .modfile, #patch .addfile, #patch .delfile, #patch .propset, #patch .binary, #patch .copfile {border:1px solid #ccc;margin:10px 0;}
#patch ins {background:#dfd;text-decoration:none;display:block;padding:0 10px;}
#patch del {background:#fdd;text-decoration:none;display:block;padding:0 10px;}
#patch .lines, .info {color:#888;background:#fff;}
--></style>
<title>[13641] trunk/wp-admin: Correct subdomain handling in network.php.</title>
</head>
<body>

<div id="msg">
<dl>
<dt>Revision</dt> <dd><a href="http://trac.wordpress.org/changeset/13641">13641</a></dd>
<dt>Author</dt> <dd>nacin</dd>
<dt>Date</dt> <dd>2010-03-10 08:17:07 +0000 (Wed, 10 Mar 2010)</dd>
</dl>

<h3>Log Message</h3>
<pre>Correct subdomain handling in network.php. Pass around boolean values instead of 'yes' and 'no'. see <a href="http://trac.wordpress.org/ticket/11816">#11816</a></pre>

<h3>Modified Paths</h3>
<ul>
<li><a href="#trunkwpadminincludesschemaphp">trunk/wp-admin/includes/schema.php</a></li>
<li><a href="#trunkwpadminnetworkphp">trunk/wp-admin/network.php</a></li>
</ul>

</div>
<div id="patch">
<h3>Diff</h3>
<a id="trunkwpadminincludesschemaphp"></a>
<div class="modfile"><h4>Modified: trunk/wp-admin/includes/schema.php (13640 => 13641)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/wp-admin/includes/schema.php        2010-03-10 08:08:27 UTC (rev 13640)
+++ trunk/wp-admin/includes/schema.php        2010-03-10 08:17:07 UTC (rev 13641)
</span><span class="lines">@@ -620,7 +620,7 @@
</span><span class="cx">  *
</span><span class="cx">  * @param int $network_id id of network to populate
</span><span class="cx">  */
</span><del>-function populate_network( $network_id = 1, $domain = '', $email = '', $site_name = '', $path = '/', $vhost = 'no' ) {
</del><ins>+function populate_network( $network_id = 1, $domain = '', $email = '', $site_name = '', $path = '/', $subdomain_install = false ) {
</ins><span class="cx">         global $wpdb, $current_site, $wp_db_version, $wp_rewrite;
</span><span class="cx"> 
</span><span class="cx">         $msg = '';
</span><span class="lines">@@ -732,25 +732,25 @@
</span><span class="cx">                 }
</span><span class="cx">         }
</span><span class="cx"> 
</span><del>-        if ( $vhost == 'yes' )
</del><ins>+        if ( $subdomain_install )
</ins><span class="cx">                 update_option( 'permalink_structure', '/%year%/%monthnum%/%day%/%postname%/');
</span><span class="cx">         else
</span><span class="cx">                 update_option( 'permalink_structure', '/blog/%year%/%monthnum%/%day%/%postname%/');
</span><span class="cx"> 
</span><span class="cx">         $wp_rewrite-&gt;flush_rules();
</span><span class="cx"> 
</span><del>-        if ( $vhost == 'yes' ) {
</del><ins>+        if ( $subdomain_install ) {
</ins><span class="cx">                 $vhost_ok = false;
</span><span class="cx">                 $hostname = substr( md5( time() ), 0, 6 ) . '.' . $domain; // Very random hostname!
</span><span class="cx">                 $page = wp_remote_get( 'http://' . $hostname, array( 'timeout' =&gt; 5, 'httpversion' =&gt; '1.1' ) );
</span><del>-                if ( is_object( $page ) &amp;&amp; is_wp_error( $page ) ) {
</del><ins>+                if ( is_wp_error( $page ) ) {
</ins><span class="cx">                         foreach ( $page-&gt;get_error_messages() as $err ) {
</span><span class="cx">                                 $errstr = $err;
</span><span class="cx">                         }
</span><span class="cx">                 } elseif( $page[ 'response' ][ 'code' ] == 200 ) {
</span><span class="cx">                                 $vhost_ok = true;
</span><span class="cx">                 }
</span><del>-                if ( !$vhost_ok ) {
</del><ins>+                if ( ! $vhost_ok ) {
</ins><span class="cx">                         // @todo Update this to reflect the merge. Also: Multisite readme file, or remove the &lt;blockquote&gt; tags.
</span><span class="cx">                         $msg = '&lt;h2&gt;' . esc_html__( 'Warning! Wildcard DNS may not be configured correctly!' ) . '&lt;/h2&gt;';
</span><span class="cx">                         $msg .= '&lt;p&gt;' . __( 'To use the subdomain feature of WordPress MU you must have a wildcard entry in your dns. The installer attempted to contact a random hostname ($hostname) on your domain but failed. It returned this error message:' ) . '&lt;br /&gt;';
</span></span></pre></div>
<a id="trunkwpadminnetworkphp"></a>
<div class="modfile"><h4>Modified: trunk/wp-admin/network.php (13640 => 13641)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/wp-admin/network.php        2010-03-10 08:08:27 UTC (rev 13640)
+++ trunk/wp-admin/network.php        2010-03-10 08:17:07 UTC (rev 13641)
</span><span class="lines">@@ -98,11 +98,11 @@
</span><span class="cx">                 &lt;?php } ?&gt;
</span><span class="cx">                 &lt;table class=&quot;form-table&quot;&gt;
</span><span class="cx">                         &lt;tr&gt;
</span><del>-                                &lt;th&gt;&lt;label&gt;&lt;input type='radio' name='vhost' value='yes'&lt;?php checked( $rewrite_enabled ); ?&gt; /&gt; Sub-domains&lt;/label&gt;&lt;/th&gt;
</del><ins>+                                &lt;th&gt;&lt;label&gt;&lt;input type='radio' name='subdomain_install' value='1'&lt;?php checked( $rewrite_enabled ); ?&gt; /&gt; Sub-domains&lt;/label&gt;&lt;/th&gt;
</ins><span class="cx">                                 &lt;td&gt;&lt;?php _e('like &lt;code&gt;site1.example.com&lt;/code&gt; and &lt;code&gt;site2.example.com&lt;/code&gt;'); ?&gt;&lt;/td&gt;
</span><span class="cx">                         &lt;/tr&gt;
</span><span class="cx">                         &lt;tr&gt;
</span><del>-                                &lt;th&gt;&lt;label&gt;&lt;input type='radio' name='vhost' value='no'&lt;?php checked( ! $rewrite_enabled ); ?&gt; /&gt; Sub-directories&lt;/label&gt;&lt;/th&gt;
</del><ins>+                                &lt;th&gt;&lt;label&gt;&lt;input type='radio' name='subdomain_install' value='0'&lt;?php checked( ! $rewrite_enabled ); ?&gt; /&gt; Sub-directories&lt;/label&gt;&lt;/th&gt;
</ins><span class="cx">                                 &lt;td&gt;&lt;?php _e('like &lt;code&gt;example.com/site1&lt;/code&gt; and &lt;code&gt;example.com/site2&lt;/code&gt;'); ?&gt;&lt;/td&gt;
</span><span class="cx">                         &lt;/tr&gt;
</span><span class="cx">                 &lt;/table&gt;
</span><span class="lines">@@ -168,25 +168,31 @@
</span><span class="cx">  */
</span><span class="cx"> function network_step2() {
</span><span class="cx">         global $base, $wpdb;
</span><del>-        if ( ! $_POST ) :
-                if ( is_multisite() ) : ?&gt;
</del><ins>+        if ( $_POST ) {
+                $vhost = (bool) $_POST['subdomain_install'];
+        } else {
+                if ( is_multisite() ) {
+                        $vhost = is_subdomain_install();
+?&gt;
</ins><span class="cx">         &lt;div class=&quot;updated&quot;&gt;&lt;p&gt;&lt;strong&gt;&lt;?php _e( 'Notice: The Network feature is already enabled.' ); ?&gt;&lt;/strong&gt; &lt;?php _e( 'The original configuration steps are shown here for reference.' ); ?&gt;&lt;/p&gt;&lt;/div&gt;
</span><del>-&lt;?php        else : ?&gt;
</del><ins>+&lt;?php        } else {
+                        $vhost = false; // @todo.
+?&gt;
</ins><span class="cx">         &lt;div class=&quot;error&quot;&gt;&lt;p&gt;&lt;strong&gt;&lt;?php _e('Warning:'); ?&gt;&lt;/strong&gt; &lt;?php _e( 'An existing WordPress network was detected.' ); ?&gt;&lt;/p&gt;&lt;/div&gt;
</span><span class="cx">         &lt;p&gt;&lt;?php _e( 'Please complete the configuration steps. To create a new network, you will need to empty or remove the network database tables.' ); ?&gt;&lt;/p&gt;
</span><span class="cx">                 &lt;h3&gt;&lt;?php esc_html_e( 'Enabling the Network' ); ?&gt;&lt;/h3&gt;
</span><span class="cx">                 &lt;p&gt;&lt;?php _e( 'Complete the following steps to enable the features for creating a network of sites.' ); ?&gt;&lt;/p&gt;
</span><span class="cx">                 &lt;div class=&quot;updated inline&quot;&gt;&lt;p&gt;&lt;?php _e( '&lt;strong&gt;Caution:&lt;/strong&gt; We recommend you backup your existing &lt;code&gt;wp-config.php&lt;/code&gt; and &lt;code&gt;.htaccess&lt;/code&gt; files.' ); ?&gt;&lt;/p&gt;&lt;/div&gt;
</span><span class="cx"> &lt;?php
</span><del>-                endif;
-        endif;
</del><ins>+                }
+        }
</ins><span class="cx"> ?&gt;
</span><span class="cx">                 &lt;ol&gt;
</span><span class="cx">                         &lt;li&gt;&lt;p&gt;&lt;?php printf( __( 'Create a &lt;code&gt;blogs.dir&lt;/code&gt; directory in &lt;code&gt;%s&lt;/code&gt;. This directory is used to stored uploaded media for your additional sites and must be writeable by the web server.' ), WP_CONTENT_DIR ); ?&gt;&lt;/p&gt;&lt;/li&gt;
</span><span class="cx">                         &lt;li&gt;&lt;p&gt;&lt;?php printf( __( 'Add the following to your &lt;code&gt;wp-config.php&lt;/code&gt; file in &lt;code&gt;%s&lt;/code&gt;:' ), ABSPATH ); ?&gt;&lt;/p&gt;
</span><span class="cx">                                 &lt;textarea class=&quot;code&quot; readonly=&quot;readonly&quot; cols=&quot;100&quot; rows=&quot;7&quot;&gt;
</span><span class="cx"> define( 'MULTISITE', true );
</span><del>-define( 'VHOST', '&lt;?php echo ( ! empty( $_POST['vhost'] ) &amp;&amp; 'yes' == stripslashes( $_POST['vhost'] ) ) ? 'yes' : 'no'; ?&gt;' );
</del><ins>+define( 'VHOST', '&lt;?php echo $vhost ? 'yes' : 'no'; ?&gt;' );
</ins><span class="cx"> $base = '&lt;?php echo $base; ?&gt;';
</span><span class="cx"> define( 'DOMAIN_CURRENT_SITE', '&lt;?php echo get_clean_basedomain(); ?&gt;' );
</span><span class="cx"> define( 'PATH_CURRENT_SITE', '&lt;?php echo $base; ?&gt;' );
</span><span class="lines">@@ -259,19 +265,18 @@
</span><span class="cx">         }
</span><span class="cx"> }
</span><span class="cx"> 
</span><ins>+$base = trailingslashit( stripslashes( dirname( dirname( $_SERVER['SCRIPT_NAME'] ) ) ) );
+
</ins><span class="cx"> if ( $_POST ) {
</span><span class="cx">         check_admin_referer( 'install-network-1' );
</span><span class="cx"> 
</span><del>-        // Install!
-        $base = trailingslashit( stripslashes( dirname( dirname( $_SERVER['SCRIPT_NAME'] ) ) ) );
-
</del><span class="cx">         require_once( ABSPATH . 'wp-admin/includes/upgrade.php' );
</span><span class="cx">         // create network tables
</span><span class="cx">         install_network();
</span><span class="cx">         $hostname = get_clean_basedomain();
</span><del>-        $vhost = 'localhost' == $hostname ? false : (bool) $_POST['vhost'];
</del><ins>+        $subdomain_install = 'localhost' == $hostname ? false : (bool) $_POST['subdomain_install'];
</ins><span class="cx">         if ( ! network_domain_check() )
</span><del>-                populate_network( 1, get_clean_basedomain(), sanitize_email( $_POST['email'] ), $_POST['weblog_title'], $base, $vhost );
</del><ins>+                populate_network( 1, get_clean_basedomain(), sanitize_email( $_POST['email'] ), $_POST['weblog_title'], $base, $subdomain_install );
</ins><span class="cx">         // create wp-config.php / htaccess
</span><span class="cx">         network_step2();
</span><span class="cx"> } elseif ( is_multisite() || network_domain_check() ) {
</span></span></pre>
</div>
</div>

</body>
</html>