WP_Recovery_Mode::handle_error( array $error ): true|WP_Error

Handles a fatal error occurring.


Description

The calling API should immediately die() after calling this function.


Top ↑

Parameters

$error array Required
Error details from error_get_last().

Top ↑

Return

true|WP_Error True if the error was handled and headers have already been sent.
Or the request will exit to try and catch multiple errors at once.
WP_Error if an error occurred preventing it from being handled.


Top ↑

Source

File: wp-includes/class-wp-recovery-mode.php. View all references

public function handle_error( array $error ) {

	$extension = $this->get_extension_for_error( $error );

	if ( ! $extension || $this->is_network_plugin( $extension ) ) {
		return new WP_Error( 'invalid_source', __( 'Error not caused by a plugin or theme.' ) );
	}

	if ( ! $this->is_active() ) {
		if ( ! is_protected_endpoint() ) {
			return new WP_Error( 'non_protected_endpoint', __( 'Error occurred on a non-protected endpoint.' ) );
		}

		if ( ! function_exists( 'wp_generate_password' ) ) {
			require_once ABSPATH . WPINC . '/pluggable.php';
		}

		return $this->email_service->maybe_send_recovery_mode_email( $this->get_email_rate_limit(), $error, $extension );
	}

	if ( ! $this->store_error( $error ) ) {
		return new WP_Error( 'storage_error', __( 'Failed to store the error.' ) );
	}

	if ( headers_sent() ) {
		return true;
	}

	$this->redirect_protected();
}


Top ↑

Changelog

Changelog
Version Description
5.2.0 Introduced.

Top ↑

User Contributed Notes

You must log in before being able to contribute a note or feedback.