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:
parent
06338d1653
commit
39458e741e
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user