WordPress 4.3
[autoinstalls/wordpress.git] / wp-admin / network / upgrade.php
1 <?php
2 /**
3  * Multisite upgrade administration panel.
4  *
5  * @package WordPress
6  * @subpackage Multisite
7  * @since 3.0.0
8  */
9
10 /** Load WordPress Administration Bootstrap */
11 require_once( dirname( __FILE__ ) . '/admin.php' );
12
13 if ( ! is_multisite() )
14         wp_die( __( 'Multisite support is not enabled.' ) );
15
16 require_once( ABSPATH . WPINC . '/http.php' );
17
18 $title = __( 'Upgrade Network' );
19 $parent_file = 'upgrade.php';
20
21 get_current_screen()->add_help_tab( array(
22         'id'      => 'overview',
23         'title'   => __('Overview'),
24         'content' =>
25                 '<p>' . __('Only use this screen once you have updated to a new version of WordPress through Updates/Available Updates (via the Network Administration navigation menu or the Toolbar). Clicking the Upgrade Network button will step through each site in the network, five at a time, and make sure any database updates are applied.') . '</p>' .
26                 '<p>' . __('If a version update to core has not happened, clicking this button won&#8217;t affect anything.') . '</p>' .
27                 '<p>' . __('If this process fails for any reason, users logging in to their sites will force the same update.') . '</p>'
28 ) );
29
30 get_current_screen()->set_help_sidebar(
31         '<p><strong>' . __('For more information:') . '</strong></p>' .
32         '<p>' . __('<a href="https://codex.wordpress.org/Network_Admin_Updates_Screen" target="_blank">Documentation on Upgrade Network</a>') . '</p>' .
33         '<p>' . __('<a href="https://wordpress.org/support/" target="_blank">Support Forums</a>') . '</p>'
34 );
35
36 require_once( ABSPATH . 'wp-admin/admin-header.php' );
37
38 if ( ! current_user_can( 'manage_network' ) )
39         wp_die( __( 'You do not have permission to access this page.' ), 403 );
40
41 echo '<div class="wrap">';
42 echo '<h1>' . __( 'Upgrade Network' ) . '</h1>';
43
44 $action = isset($_GET['action']) ? $_GET['action'] : 'show';
45
46 switch ( $action ) {
47         case "upgrade":
48                 $n = ( isset($_GET['n']) ) ? intval($_GET['n']) : 0;
49
50                 if ( $n < 5 ) {
51                         /**
52                          * @global string $wp_db_version
53                          */
54                         global $wp_db_version;
55                         update_site_option( 'wpmu_upgrade_site', $wp_db_version );
56                 }
57
58                 $blogs = $wpdb->get_results( "SELECT blog_id FROM {$wpdb->blogs} WHERE site_id = '{$wpdb->siteid}' AND spam = '0' AND deleted = '0' AND archived = '0' ORDER BY registered DESC LIMIT {$n}, 5", ARRAY_A );
59                 if ( empty( $blogs ) ) {
60                         echo '<p>' . __( 'All done!' ) . '</p>';
61                         break;
62                 }
63                 echo "<ul>";
64                 foreach ( (array) $blogs as $details ) {
65                         switch_to_blog( $details['blog_id'] );
66                         $siteurl = site_url();
67                         $upgrade_url = admin_url( 'upgrade.php?step=upgrade_db' );
68                         restore_current_blog();
69
70                         echo "<li>$siteurl</li>";
71
72                         $response = wp_remote_get( $upgrade_url, array( 'timeout' => 120, 'httpversion' => '1.1' ) );
73                         if ( is_wp_error( $response ) ) {
74                                 wp_die( sprintf(
75                                         /* translators: 1: site url, 2: server error message */
76                                         __( 'Warning! Problem updating %1$s. Your server may not be able to connect to sites running on it. Error message: %2$s' ),
77                                         $siteurl,
78                                         '<em>' . $response->get_error_message() . '</em>'
79                                 ) );
80                         }
81
82                         /**
83                          * Fires after the Multisite DB upgrade for each site is complete.
84                          *
85                          * @since MU
86                          *
87                          * @param array|WP_Error $response The upgrade response array or WP_Error on failure.
88                          */
89                         do_action( 'after_mu_upgrade', $response );
90                         /**
91                          * Fires after each site has been upgraded.
92                          *
93                          * @since MU
94                          *
95                          * @param int $blog_id The id of the blog.
96                          */
97                         do_action( 'wpmu_upgrade_site', $details[ 'blog_id' ] );
98                 }
99                 echo "</ul>";
100                 ?><p><?php _e( 'If your browser doesn&#8217;t start loading the next page automatically, click this link:' ); ?> <a class="button" href="upgrade.php?action=upgrade&amp;n=<?php echo ($n + 5) ?>"><?php _e("Next Sites"); ?></a></p>
101                 <script type="text/javascript">
102                 <!--
103                 function nextpage() {
104                         location.href = "upgrade.php?action=upgrade&n=<?php echo ($n + 5) ?>";
105                 }
106                 setTimeout( "nextpage()", 250 );
107                 //-->
108                 </script><?php
109         break;
110         case 'show':
111         default:
112                 if ( get_site_option( 'wpmu_upgrade_site' ) != $GLOBALS['wp_db_version'] ) :
113                 ?>
114                 <h3><?php _e( 'Database Upgrade Required' ); ?></h3>
115                 <p><?php _e( 'WordPress has been updated! Before we send you on your way, we need to individually upgrade the sites in your network.' ); ?></p>
116                 <?php endif; ?>
117
118                 <p><?php _e( 'The database upgrade process may take a little while, so please be patient.' ); ?></p>
119                 <p><a class="button" href="upgrade.php?action=upgrade"><?php _e( 'Upgrade Network' ); ?></a></p>
120                 <?php
121                 /**
122                  * Fires before the footer on the network upgrade screen.
123                  *
124                  * @since MU
125                  */
126                 do_action( 'wpmu_upgrade_page' );
127         break;
128 }
129 ?>
130 </div>
131
132 <?php include( ABSPATH . 'wp-admin/admin-footer.php' ); ?>