2008-02-11 06:45:54 +01:00
< ? php
require_once ( 'admin.php' );
if ( ! current_user_can ( 'edit_plugins' ) )
2008-05-22 02:06:41 +02:00
wp_die ( '<p>' . __ ( 'You do not have sufficient permissions to update plugins for this blog.' ) . '</p>' );
2008-02-11 06:45:54 +01:00
2008-03-11 17:37:44 +01:00
function request_filesystem_credentials ( $form_post , $type = '' , $error = false ) {
2008-03-21 22:05:22 +01:00
$req_cred = apply_filters ( 'request_filesystem_credentials' , '' , $form_post , $type , $error );
if ( '' !== $req_cred )
return $req_cred ;
2008-02-11 06:45:54 +01:00
if ( empty ( $type ) )
$type = get_filesystem_method ();
if ( 'direct' == $type )
2008-03-20 18:22:43 +01:00
return true ;
2008-03-14 20:11:41 +01:00
if ( ! $credentials = get_option ( 'ftp_credentials' ) )
$credentials = array ();
// If defined, set it to that, Else, If POST'd, set it to that, If not, Set it to whatever it previously was(saved details in option)
$credentials [ 'hostname' ] = defined ( 'FTP_HOST' ) ? FTP_HOST : ( ! empty ( $_POST [ 'hostname' ]) ? $_POST [ 'hostname' ] : $credentials [ 'hostname' ]);
$credentials [ 'username' ] = defined ( 'FTP_USER' ) ? FTP_USER : ( ! empty ( $_POST [ 'username' ]) ? $_POST [ 'username' ] : $credentials [ 'username' ]);
$credentials [ 'password' ] = defined ( 'FTP_PASS' ) ? FTP_PASS : ( ! empty ( $_POST [ 'password' ]) ? $_POST [ 'password' ] : $credentials [ 'password' ]);
2008-05-18 22:09:52 +02:00
$credentials [ 'ssl' ] = defined ( 'FTP_SSL' ) ? FTP_SSL : ( isset ( $_POST [ 'ssl' ]) ? $_POST [ 'ssl' ] : $credentials [ 'ssl' ]);
2008-02-11 06:45:54 +01:00
2008-03-14 20:11:41 +01:00
if ( ! $error && ! empty ( $credentials [ 'password' ]) && ! empty ( $credentials [ 'username' ]) && ! empty ( $credentials [ 'hostname' ]) ) {
2008-02-11 06:45:54 +01:00
$stored_credentials = $credentials ;
unset ( $stored_credentials [ 'password' ]);
update_option ( 'ftp_credentials' , $stored_credentials );
return $credentials ;
}
$hostname = '' ;
$username = '' ;
$password = '' ;
$ssl = '' ;
2008-03-14 20:11:41 +01:00
if ( ! empty ( $credentials ) )
2008-02-11 06:45:54 +01:00
extract ( $credentials , EXTR_OVERWRITE );
2008-03-14 20:11:41 +01:00
if ( $error )
2008-03-11 17:37:44 +01:00
echo '<div id="message" class="error"><p>' . __ ( '<strong>Error:</strong> There was an error connecting to the server, Please verify the settings are correct.' ) . '</p></div>' ;
2008-02-11 06:45:54 +01:00
?>
< form action = " <?php echo $form_post ?> " method = " post " >
< div class = " wrap " >
< h2 >< ? php _e ( 'FTP Connection Information' ) ?> </h2>
< p >< ? php _e ( 'To perform the requested update, FTP connection information is required.' ) ?> </p>
2008-02-24 05:33:10 +01:00
< table class = " form-table " >
2008-02-11 06:45:54 +01:00
< tr valign = " top " >
2008-05-04 12:37:06 +02:00
< th scope = " row " >< label for = " hostname " >< ? php _e ( 'Hostname:' ) ?> </label></th>
2008-03-14 20:11:41 +01:00
< td >< input name = " hostname " type = " text " id = " hostname " value = " <?php echo attribute_escape( $hostname ) ?> " < ? php if ( defined ( 'FTP_HOST' ) ) echo ' disabled="disabled"' ?> size="40" /></td>
2008-02-11 06:45:54 +01:00
</ tr >
< tr valign = " top " >
2008-05-04 12:37:06 +02:00
< th scope = " row " >< label for = " username " >< ? php _e ( 'Username:' ) ?> </label></th>
2008-03-14 20:11:41 +01:00
< td >< input name = " username " type = " text " id = " username " value = " <?php echo attribute_escape( $username ) ?> " < ? php if ( defined ( 'FTP_USER' ) ) echo ' disabled="disabled"' ?> size="40" /></td>
2008-02-11 06:45:54 +01:00
</ tr >
< tr valign = " top " >
2008-05-04 12:37:06 +02:00
< th scope = " row " >< label for = " password " >< ? php _e ( 'Password:' ) ?> </label></th>
2008-03-14 23:20:24 +01:00
< td >< input name = " password " type = " password " id = " password " value = " " < ? php if ( defined ( 'FTP_PASS' ) ) echo ' disabled="disabled"' ?> size="40" /><?php if( defined('FTP_PASS') && !empty($password) ) echo '<em>'.__('(Password not shown)').'</em>'; ?></td>
2008-02-11 06:45:54 +01:00
</ tr >
< tr valign = " top " >
2008-05-04 12:37:06 +02:00
< th scope = " row " >< label for = " ssl " >< ? php _e ( 'Use SSL:' ) ?> </label></th>
2008-02-11 06:45:54 +01:00
< td >
2008-03-14 20:11:41 +01:00
< select name = " ssl " id = " ssl " < ? php if ( defined ( 'FTP_SSL' ) ) echo ' disabled="disabled"' ?> >
2008-02-11 06:45:54 +01:00
< ? php
foreach ( array ( 0 => __ ( 'No' ), 1 => __ ( 'Yes' )) as $key => $value ) :
$selected = ( $ssl == $value ) ? 'selected="selected"' : '' ;
echo " \n \t <option value=' $key ' $selected > " . $value . '</option>' ;
endforeach ;
?>
</ select >
</ td >
</ tr >
</ table >
< p class = " submit " >
2008-02-20 20:30:55 +01:00
< input type = " submit " name = " submit " value = " <?php _e('Proceed'); ?> " />
2008-02-11 06:45:54 +01:00
</ p >
</ div >
</ form >
< ? php
return false ;
}
function show_message ( $message ) {
2008-03-10 08:45:46 +01:00
if ( is_wp_error ( $message ) ){
if ( $message -> get_error_data () )
$message = $message -> get_error_message () . ': ' . $message -> get_error_data ();
else
$message = $message -> get_error_message ();
}
2008-03-22 00:02:00 +01:00
echo " <p> $message </p> \n " ;
2008-02-11 06:45:54 +01:00
}
function do_plugin_upgrade ( $plugin ) {
global $wp_filesystem ;
2008-03-11 17:37:44 +01:00
$url = wp_nonce_url ( " update.php?action=upgrade-plugin&plugin= $plugin " , " upgrade-plugin_ $plugin " );
if ( false === ( $credentials = request_filesystem_credentials ( $url )) )
return ;
2008-03-22 00:02:00 +01:00
if ( ! WP_Filesystem ( $credentials ) ) {
2008-03-11 17:37:44 +01:00
request_filesystem_credentials ( $url , '' , true ); //Failed to connect, Error and request again
2008-02-11 06:45:54 +01:00
return ;
2008-03-11 17:37:44 +01:00
}
2008-03-22 00:02:00 +01:00
2008-02-11 06:45:54 +01:00
echo '<div class="wrap">' ;
echo '<h2>' . __ ( 'Upgrade Plugin' ) . '</h2>' ;
if ( $wp_filesystem -> errors -> get_error_code () ) {
foreach ( $wp_filesystem -> errors -> get_error_messages () as $message )
show_message ( $message );
echo '</div>' ;
return ;
}
2008-05-29 19:29:32 +02:00
$was_activated = is_plugin_active ( $plugin ); //Check now, It'll be deactivated by the next line if it is
2008-03-22 00:02:00 +01:00
2008-02-11 06:45:54 +01:00
$result = wp_update_plugin ( $plugin , 'show_message' );
2008-03-22 00:02:00 +01:00
if ( is_wp_error ( $result ) ) {
2008-02-11 06:45:54 +01:00
show_message ( $result );
2008-05-29 19:29:32 +02:00
show_message ( __ ( 'Installation Failed' ) );
2008-03-22 00:02:00 +01:00
} else {
2008-05-27 19:55:24 +02:00
//Result is the new plugin file relative to WP_PLUGIN_DIR
2008-05-29 19:29:32 +02:00
show_message ( __ ( 'Plugin upgraded successfully' ) );
2008-03-22 00:02:00 +01:00
if ( $result && $was_activated ){
show_message ( __ ( 'Attempting reactivation of the plugin' ));
echo '<iframe style="border:0" width="100%" height="170px" src="' . wp_nonce_url ( 'update.php?action=activate-plugin&plugin=' . $result , 'activate-plugin_' . $result ) . '"></iframe>' ;
}
}
2008-02-11 06:45:54 +01:00
echo '</div>' ;
}
if ( isset ( $_GET [ 'action' ]) ) {
2008-03-22 00:02:00 +01:00
$plugin = isset ( $_GET [ 'plugin' ]) ? trim ( $_GET [ 'plugin' ]) : '' ;
2008-02-11 06:45:54 +01:00
if ( 'upgrade-plugin' == $_GET [ 'action' ] ) {
2008-03-11 17:37:44 +01:00
check_admin_referer ( 'upgrade-plugin_' . $plugin );
2008-02-11 06:45:54 +01:00
$title = __ ( 'Upgrade Plugin' );
$parent_file = 'plugins.php' ;
require_once ( 'admin-header.php' );
do_plugin_upgrade ( $plugin );
include ( 'admin-footer.php' );
2008-03-22 00:02:00 +01:00
} elseif ( 'activate-plugin' == $_GET [ 'action' ] ) {
check_admin_referer ( 'activate-plugin_' . $plugin );
if ( ! isset ( $_GET [ 'failure' ]) && ! isset ( $_GET [ 'success' ]) ) {
wp_redirect ( 'update.php?action=activate-plugin&failure=true&plugin=' . $plugin . '&_wpnonce=' . $_GET [ '_wpnonce' ] );
activate_plugin ( $plugin );
wp_redirect ( 'update.php?action=activate-plugin&success=true&plugin=' . $plugin . '&_wpnonce=' . $_GET [ '_wpnonce' ] );
die ();
}
?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
< html xmlns = " http://www.w3.org/1999/xhtml " < ? php do_action ( 'admin_xml_ns' ); ?> <?php language_attributes(); ?>>
< head >
< meta http - equiv = " Content-Type " content = " <?php bloginfo('html_type'); ?>; charset=<?php echo get_option('blog_charset'); ?> " />
< title >< ? php bloginfo ( 'name' ) ?> › <?php _e('Plugin Reactivation'); ?> — <?php _e('WordPress'); ?></title>
< ? php
2008-05-22 02:06:41 +02:00
wp_admin_css ( 'global' , true );
wp_admin_css ( 'colors' , true );
2008-03-22 00:02:00 +01:00
?>
</ head >
< body >
< ? php
if ( isset ( $_GET [ 'success' ]) )
echo '<p>' . __ ( 'Plugin reactivated successfully.' ) . '</p>' ;
if ( isset ( $_GET [ 'failure' ]) ){
echo '<p>' . __ ( 'Plugin failed to reactivate due to a fatal error.' ) . '</p>' ;
error_reporting ( E_ALL ^ E_NOTICE );
@ ini_set ( 'display_errors' , true ); //Ensure that Fatal errors are displayed.
2008-05-27 19:55:24 +02:00
include ( WP_PLUGIN_DIR . '/' . $plugin );
2008-03-22 00:02:00 +01:00
}
echo " </body></html> " ;
2008-03-02 21:17:30 +01:00
}
2008-02-11 06:45:54 +01:00
}
2008-03-11 17:37:44 +01:00
?>