diff --git a/wp-admin/authorize-application.php b/wp-admin/authorize-application.php index 294d4fe10e..94327b05b7 100644 --- a/wp-admin/authorize-application.php +++ b/wp-admin/authorize-application.php @@ -88,7 +88,7 @@ if ( is_wp_error( $is_valid ) ) { ); } -if ( ! empty( $_SERVER['PHP_AUTH_USER'] ) || ! empty( $_SERVER['PHP_AUTH_PW'] ) ) { +if ( wp_is_site_protected_by_basic_auth( 'front' ) ) { wp_die( __( 'Your website appears to use Basic Authentication, which is not currently compatible with Application Passwords.' ), __( 'Cannot Authorize Application' ), diff --git a/wp-admin/user-edit.php b/wp-admin/user-edit.php index 4177288547..b09f14fac5 100644 --- a/wp-admin/user-edit.php +++ b/wp-admin/user-edit.php @@ -739,7 +739,7 @@ endif; } } - if ( empty( $_SERVER['PHP_AUTH_USER'] ) && empty( $_SERVER['PHP_AUTH_PW'] ) ) { + if ( ! wp_is_site_protected_by_basic_auth( 'front' ) ) { ?>
diff --git a/wp-includes/load.php b/wp-includes/load.php index 6bd7614ecd..15feeeaf3c 100644 --- a/wp-includes/load.php +++ b/wp-includes/load.php @@ -1685,3 +1685,46 @@ function wp_is_xml_request() { return false; } + +/** + * Checks if this site is protected by HTTP Basic Auth. + * + * At the moment, this merely checks for the present of Basic Auth credentials. Therefore, calling this function + * with a context different from the current context may give inaccurate results. In a future release, this + * evaluation may be made more robust. + * + * Currently, this is only used by Application Passwords to prevent a conflict since it also utilizes Basic Auth. + * + * @since 5.6.1 + * + * @global string $pagenow The current page. + * + * @param string $context The context to check for protection. Accepts 'login', 'admin', and 'front'. Defaults to the current context. + * + * @return bool + */ +function wp_is_site_protected_by_basic_auth( $context = '' ) { + global $pagenow; + + if ( ! $context ) { + if ( 'wp-login.php' === $pagenow ) { + $context = 'login'; + } elseif ( is_admin() ) { + $context = 'admin'; + } else { + $context = 'front'; + } + } + + $is_protected = ! empty( $_SERVER['PHP_AUTH_USER'] ) || ! empty( $_SERVER['PHP_AUTH_PW'] ); + + /** + * Filters whether a site is protected by HTTP Basic Auth. + * + * @since 5.6.1 + * + * @param bool $is_protected Whether the site is protected by Basic Auth. + * @param string $context The context to check for protection. One of 'login', 'admin', or 'front'. + */ + return apply_filters( 'wp_is_site_protected_by_basic_auth', $is_protected, $context ); +} diff --git a/wp-includes/version.php b/wp-includes/version.php index de183f9685..d12758edb2 100644 --- a/wp-includes/version.php +++ b/wp-includes/version.php @@ -13,7 +13,7 @@ * * @global string $wp_version */ -$wp_version = '5.6.1-alpha-50043'; +$wp_version = '5.6.1-alpha-50044'; /** * Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.