From a69b052f3f528fd7a491df734ba6da3c7c7f0108 Mon Sep 17 00:00:00 2001 From: Sergey Biryukov Date: Mon, 3 Sep 2018 21:01:26 +0000 Subject: [PATCH] Privacy: Ensure the user request email is sent in the requested user's locale (or the site's default locale if they are not a registered user) when the administrator creating the request uses a different locale. Props desrosj, Chouby, iandunn, lbenicio, birgire, earnjam, swissspidy, garrett-eclipse. Merges [43568] to the 4.9 branch. Fixes #43985. Built from https://develop.svn.wordpress.org/branches/4.9@43614 git-svn-id: http://core.svn.wordpress.org/branches/4.9@43443 1a063a9b-81f0-0310-95a4-ce76da25c4cd --- wp-admin/includes/file.php | 4 ++-- wp-includes/user.php | 28 +++++++++++++++++++++++----- wp-includes/version.php | 2 +- 3 files changed, 26 insertions(+), 8 deletions(-) diff --git a/wp-admin/includes/file.php b/wp-admin/includes/file.php index b8a0d9116a..0806477080 100644 --- a/wp-admin/includes/file.php +++ b/wp-admin/includes/file.php @@ -2059,7 +2059,7 @@ function wp_privacy_send_personal_data_export_email( $request_id ) { $request = wp_get_user_request_data( $request_id ); if ( ! $request || 'export_personal_data' !== $request->action_name ) { - return new WP_Error( 'invalid', __( 'Invalid request ID when sending personal data export email.' ) ); + return new WP_Error( 'invalid_request', __( 'Invalid request ID when sending personal data export email.' ) ); } /** This filter is documented in wp-includes/functions.php */ @@ -2119,7 +2119,7 @@ All at ###SITENAME### ); if ( ! $mail_success ) { - return new WP_Error( 'error', __( 'Unable to send personal data export email.' ) ); + return new WP_Error( 'privacy_email_error', __( 'Unable to send personal data export email.' ) ); } return true; diff --git a/wp-includes/user.php b/wp-includes/user.php index ef3bc57dea..c52a619e7f 100644 --- a/wp-includes/user.php +++ b/wp-includes/user.php @@ -3279,16 +3279,25 @@ function wp_user_request_action_description( $action_name ) { * @since 4.9.6 * * @param string $request_id ID of the request created via wp_create_user_request(). - * @return WP_Error|bool Will return true/false based on the success of sending the email, or a WP_Error object. + * @return bool|WP_Error True on success, `WP_Error` on failure. */ function wp_send_user_request( $request_id ) { $request_id = absint( $request_id ); $request = wp_get_user_request_data( $request_id ); if ( ! $request ) { - return new WP_Error( 'user_request_error', __( 'Invalid request.' ) ); + return new WP_Error( 'invalid_request', __( 'Invalid user request.' ) ); } + // Localize message content for user; fallback to site default for visitors. + if ( ! empty( $request->user_id ) ) { + $locale = get_user_locale( $request->user_id ); + } else { + $locale = get_locale(); + } + + $switched_locale = switch_to_locale( $locale ); + $email_data = array( 'request' => $request, 'email' => $request->email, @@ -3376,7 +3385,17 @@ All at ###SITENAME### */ $subject = apply_filters( 'user_request_action_email_subject', $subject, $email_data['sitename'], $email_data ); - return wp_mail( $email_data['email'], $subject, $content ); + $email_sent = wp_mail( $email_data['email'], $subject, $content ); + + if ( $switched_locale ) { + restore_previous_locale(); + } + + if ( ! $email_sent ) { + return new WP_Error( 'privacy_email_error', __( 'Unable to send personal data export confirmation email.' ) ); + } + + return true; } /** @@ -3426,7 +3445,7 @@ function wp_validate_user_request_key( $request_id, $key ) { $request = wp_get_user_request_data( $request_id ); if ( ! $request ) { - return new WP_Error( 'user_request_error', __( 'Invalid request.' ) ); + return new WP_Error( 'invalid_request', __( 'Invalid request.' ) ); } if ( ! in_array( $request->status, array( 'request-pending', 'request-failed' ), true ) ) { @@ -3513,7 +3532,6 @@ final class WP_User_Request { * * @var int */ - public $user_id = 0; /** diff --git a/wp-includes/version.php b/wp-includes/version.php index 84e9129310..930771bb6b 100644 --- a/wp-includes/version.php +++ b/wp-includes/version.php @@ -4,7 +4,7 @@ * * @global string $wp_version */ -$wp_version = '4.9.9-alpha-43613'; +$wp_version = '4.9.9-alpha-43614'; /** * Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.