Bootstrap/Load: Ensure WP_Fatal_Error_Handler does not conflict with existing mechanisms treating fatal errors.

Prior to this change, resuming or activating a plugin or theme that is still broken would result in a redirect loop if in recovery mode. If outside recovery mode, it would cause the error template to be displayed.

Furthermore this applies to breaking a plugin or theme when editing from the backend.

Props aandrewdixon, azaozz, dhanukanuwan, henrywright, ocean90, ohiosierra, PandelisZ, xkon.
Fixes #46045, #46751.


git-svn-id: https://develop.svn.wordpress.org/trunk@45114 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Felix Arntz 2019-04-05 15:19:50 +00:00
parent 99a0145ba1
commit 7f6adbb345
4 changed files with 9 additions and 0 deletions

View File

@ -631,9 +631,11 @@ function activate_plugin( $plugin, $redirect = '', $network_wide = false, $silen
if ( ! empty( $redirect ) ) { if ( ! empty( $redirect ) ) {
wp_redirect( add_query_arg( '_error_nonce', wp_create_nonce( 'plugin-activation-error_' . $plugin ), $redirect ) ); // we'll override this later if the plugin can be included without fatal error wp_redirect( add_query_arg( '_error_nonce', wp_create_nonce( 'plugin-activation-error_' . $plugin ), $redirect ) ); // we'll override this later if the plugin can be included without fatal error
} }
ob_start(); ob_start();
wp_register_plugin_realpath( WP_PLUGIN_DIR . '/' . $plugin ); wp_register_plugin_realpath( WP_PLUGIN_DIR . '/' . $plugin );
$_wp_plugin_file = $plugin; $_wp_plugin_file = $plugin;
define( 'WP_SANDBOX_SCRAPING', true );
include_once( WP_PLUGIN_DIR . '/' . $plugin ); include_once( WP_PLUGIN_DIR . '/' . $plugin );
$plugin = $_wp_plugin_file; // Avoid stomping of the $plugin variable in a plugin. $plugin = $_wp_plugin_file; // Avoid stomping of the $plugin variable in a plugin.
@ -2125,6 +2127,7 @@ function wp_clean_plugins_cache( $clear_update_cache = true ) {
* @param string $plugin Path to the plugin file relative to the plugins directory. * @param string $plugin Path to the plugin file relative to the plugins directory.
*/ */
function plugin_sandbox_scrape( $plugin ) { function plugin_sandbox_scrape( $plugin ) {
define( 'WP_SANDBOX_SCRAPING', true );
wp_register_plugin_realpath( WP_PLUGIN_DIR . '/' . $plugin ); wp_register_plugin_realpath( WP_PLUGIN_DIR . '/' . $plugin );
include( WP_PLUGIN_DIR . '/' . $plugin ); include( WP_PLUGIN_DIR . '/' . $plugin );
} }

View File

@ -859,6 +859,7 @@ function resume_theme( $theme, $redirect = '' ) {
// Load the theme's functions.php to test whether it throws a fatal error. // Load the theme's functions.php to test whether it throws a fatal error.
ob_start(); ob_start();
define( 'WP_SANDBOX_SCRAPING', true );
include $functions_path; include $functions_path;
ob_clean(); ob_clean();
} }

View File

@ -26,6 +26,10 @@ class WP_Fatal_Error_Handler {
* @since 5.2.0 * @since 5.2.0
*/ */
public function handle() { public function handle() {
if ( defined( 'WP_SANDBOX_SCRAPING' ) && WP_SANDBOX_SCRAPING ) {
return;
}
try { try {
// Bail if no error found. // Bail if no error found.
$error = $this->detect_error(); $error = $this->detect_error();

View File

@ -1444,6 +1444,7 @@ function wp_start_scraping_edited_file_errors() {
echo "###### wp_scraping_result_end:$key ######"; echo "###### wp_scraping_result_end:$key ######";
die(); die();
} }
define( 'WP_SANDBOX_SCRAPING', true );
register_shutdown_function( 'wp_finalize_scraping_edited_file_errors', $key ); register_shutdown_function( 'wp_finalize_scraping_edited_file_errors', $key );
} }