First slice of rejecting invalid Plugin and Theme zip uploads (Incompatible file structure, not containing a Plugin/Theme, etc). See #14999

git-svn-id: https://develop.svn.wordpress.org/trunk@18618 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Dion Hulse 2011-08-28 15:02:48 +00:00
parent 06338d1653
commit 39458e741e

View File

@ -52,7 +52,7 @@ class WP_Upgrader {
$this->strings['installing_package'] = __('Installing the latest version…'); $this->strings['installing_package'] = __('Installing the latest version…');
$this->strings['folder_exists'] = __('Destination folder already exists.'); $this->strings['folder_exists'] = __('Destination folder already exists.');
$this->strings['mkdir_failed'] = __('Could not create directory.'); $this->strings['mkdir_failed'] = __('Could not create directory.');
$this->strings['bad_package'] = __('Incompatible Archive.'); $this->strings['incompatible_archive'] = __('The package is corrupt or not in the correct format.');
$this->strings['maintenance_start'] = __('Enabling Maintenance mode…'); $this->strings['maintenance_start'] = __('Enabling Maintenance mode…');
$this->strings['maintenance_end'] = __('Disabling Maintenance mode…'); $this->strings['maintenance_end'] = __('Disabling Maintenance mode…');
@ -153,6 +153,9 @@ class WP_Upgrader {
if ( is_wp_error($result) ) { if ( is_wp_error($result) ) {
$wp_filesystem->delete($working_dir, true); $wp_filesystem->delete($working_dir, true);
if ( 'incompatible_archive' == $result->get_error_code() ) {
return new WP_Error( 'incompatible_archive', $this->strings['incompatible_archive'], $result->get_error_data() );
}
return $result; return $result;
} }
@ -190,7 +193,7 @@ class WP_Upgrader {
if ( 1 == count($source_files) && $wp_filesystem->is_dir( trailingslashit($source) . $source_files[0] . '/') ) //Only one folder? Then we want its contents. if ( 1 == count($source_files) && $wp_filesystem->is_dir( trailingslashit($source) . $source_files[0] . '/') ) //Only one folder? Then we want its contents.
$source = trailingslashit($source) . trailingslashit($source_files[0]); $source = trailingslashit($source) . trailingslashit($source_files[0]);
elseif ( count($source_files) == 0 ) elseif ( count($source_files) == 0 )
return new WP_Error('bad_package', $this->strings['bad_package']); //There are no files? return new WP_Error('incompatible_archive', $this->strings['incompatible_archive']); //There are no files?
//else //Its only a single file, The upgrader will use the foldername of this file as the destination folder. foldername is based on zip filename. //else //Its only a single file, The upgrader will use the foldername of this file as the destination folder. foldername is based on zip filename.
//Hook ability to change the source file location.. //Hook ability to change the source file location..
@ -391,6 +394,8 @@ class Plugin_Upgrader extends WP_Upgrader {
$this->init(); $this->init();
$this->install_strings(); $this->install_strings();
add_filter('upgrader_source_selection', array(&$this, 'check_package') );
$this->run(array( $this->run(array(
'package' => $package, 'package' => $package,
'destination' => WP_PLUGIN_DIR, 'destination' => WP_PLUGIN_DIR,
@ -399,6 +404,8 @@ class Plugin_Upgrader extends WP_Upgrader {
'hook_extra' => array() 'hook_extra' => array()
)); ));
remove_filter('upgrader_source_selection', array(&$this, 'check_package') );
if ( ! $this->result || is_wp_error($this->result) ) if ( ! $this->result || is_wp_error($this->result) )
return $this->result; return $this->result;
@ -533,6 +540,32 @@ class Plugin_Upgrader extends WP_Upgrader {
return $results; return $results;
} }
function check_package($source) {
global $wp_filesystem;
if ( is_wp_error($source) )
return $source;
$working_directory = str_replace( $wp_filesystem->wp_content_dir(), trailingslashit(WP_CONTENT_DIR), $source);
if ( ! is_dir($working_directory) ) // Sanity check, if the above fails, lets not prevent installation.
return $source;
// Check the folder contains at least 1 valid plugin.
$plugins_found = false;
foreach ( glob( $working_directory . '*.php' ) as $file ) {
$info = get_plugin_data($file, false, false);
if ( !empty( $info['Name'] ) ) {
$plugins_found = true;
break;
}
}
if ( ! $plugins_found )
return new WP_Error( 'incompatible_archive', $this->strings['incompatible_archive'] );
return $source;
}
//return plugin info. //return plugin info.
function plugin_info() { function plugin_info() {
if ( ! is_array($this->result) ) if ( ! is_array($this->result) )
@ -635,6 +668,8 @@ class Theme_Upgrader extends WP_Upgrader {
$this->init(); $this->init();
$this->install_strings(); $this->install_strings();
add_filter('upgrader_source_selection', array(&$this, 'check_package') );
$options = array( $options = array(
'package' => $package, 'package' => $package,
'destination' => WP_CONTENT_DIR . '/themes', 'destination' => WP_CONTENT_DIR . '/themes',
@ -644,6 +679,8 @@ class Theme_Upgrader extends WP_Upgrader {
$this->run($options); $this->run($options);
remove_filter('upgrader_source_selection', array(&$this, 'check_package') );
if ( ! $this->result || is_wp_error($this->result) ) if ( ! $this->result || is_wp_error($this->result) )
return $this->result; return $this->result;
@ -686,6 +723,10 @@ class Theme_Upgrader extends WP_Upgrader {
$this->run($options); $this->run($options);
remove_filter('upgrader_pre_install', array(&$this, 'current_before'), 10, 2);
remove_filter('upgrader_post_install', array(&$this, 'current_after'), 10, 2);
remove_filter('upgrader_clear_destination', array(&$this, 'delete_old_theme'), 10, 4);
if ( ! $this->result || is_wp_error($this->result) ) if ( ! $this->result || is_wp_error($this->result) )
return $this->result; return $this->result;
@ -782,6 +823,30 @@ class Theme_Upgrader extends WP_Upgrader {
return $results; return $results;
} }
function check_package($source) {
global $wp_filesystem;
if ( is_wp_error($source) )
return $source;
// Check the folder contains a valid theme
$working_directory = str_replace( $wp_filesystem->wp_content_dir(), trailingslashit(WP_CONTENT_DIR), $source);
if ( ! is_dir($working_directory) ) // Sanity check, if the above fails, lets not prevent installation.
return $source;
if ( ! file_exists( $working_directory . 'style.css' ) ) // A proper archive should have a style.css file in the single subdirectory
return new WP_Error( 'incompatible_archive', $this->strings['incompatible_archive'] );
$info = get_theme_data( $working_directory . 'style.css' );
if ( empty($info['Name']) )
return new WP_Error( 'incompatible_archive', $this->strings['incompatible_archive'] );
if ( empty($info['Template']) && ! file_exists( $working_directory . 'index.php' ) ) // If no template is set, it must have at least an index.php to be legit.
return new WP_Error( 'incompatible_archive', $this->strings['incompatible_archive'] );
return $source;
}
function current_before($return, $theme) { function current_before($return, $theme) {
if ( is_wp_error($return) ) if ( is_wp_error($return) )
@ -797,6 +862,7 @@ class Theme_Upgrader extends WP_Upgrader {
return $return; return $return;
} }
function current_after($return, $theme) { function current_after($return, $theme) {
if ( is_wp_error($return) ) if ( is_wp_error($return) )
return $return; return $return;