mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-16 13:21:22 +01:00
Privacy: Send an email notification to the user once their personal data erasure request is fulfilled.
Props desrosj, allendav, garrett-eclipse. Merges [43230] to the 4.9 branch. Fixes #43973. Built from https://develop.svn.wordpress.org/branches/4.9@43231 git-svn-id: http://core.svn.wordpress.org/branches/4.9@43060 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
2c2db8337f
commit
ad8efe232e
@ -136,6 +136,7 @@ add_action( 'upgrader_process_complete', 'wp_update_themes', 10, 0 );
|
|||||||
add_filter( 'wp_privacy_personal_data_erasure_page', 'wp_privacy_process_personal_data_erasure_page', 10, 5 );
|
add_filter( 'wp_privacy_personal_data_erasure_page', 'wp_privacy_process_personal_data_erasure_page', 10, 5 );
|
||||||
add_filter( 'wp_privacy_personal_data_export_page', 'wp_privacy_process_personal_data_export_page', 10, 7 );
|
add_filter( 'wp_privacy_personal_data_export_page', 'wp_privacy_process_personal_data_export_page', 10, 7 );
|
||||||
add_action( 'wp_privacy_personal_data_export_file', 'wp_privacy_generate_personal_data_export_file', 10 );
|
add_action( 'wp_privacy_personal_data_export_file', 'wp_privacy_generate_personal_data_export_file', 10 );
|
||||||
|
add_action( 'wp_privacy_personal_data_erased', '_wp_privacy_send_erasure_fulfillment_notification', 10 );
|
||||||
|
|
||||||
// Privacy policy text changes check.
|
// Privacy policy text changes check.
|
||||||
add_action( 'admin_init', array( 'WP_Privacy_Policy_Content', 'text_change_check' ), 100 );
|
add_action( 'admin_init', array( 'WP_Privacy_Policy_Content', 'text_change_check' ), 100 );
|
||||||
|
@ -940,6 +940,15 @@ function wp_privacy_process_personal_data_erasure_page( $response, $eraser_index
|
|||||||
|
|
||||||
_wp_privacy_completed_request( $request_id );
|
_wp_privacy_completed_request( $request_id );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fires immediately after a personal data erasure request has been marked completed.
|
||||||
|
*
|
||||||
|
* @since 4.9.6
|
||||||
|
*
|
||||||
|
* @param int $request_id The privacy request post ID associated with this request.
|
||||||
|
*/
|
||||||
|
do_action( 'wp_privacy_personal_data_erased', $request_id );
|
||||||
|
|
||||||
return $response;
|
return $response;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2988,6 +2988,120 @@ All at ###SITENAME###
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Notify the user when their erasure request is fulfilled.
|
||||||
|
*
|
||||||
|
* Without this, the user would never know if their data was actually erased.
|
||||||
|
*
|
||||||
|
* @since 4.9.6
|
||||||
|
*
|
||||||
|
* @param int $request_id The privacy request post ID associated with this request.
|
||||||
|
*/
|
||||||
|
function _wp_privacy_send_erasure_fulfillment_notification( $request_id ) {
|
||||||
|
$request_data = wp_get_user_request_data( $request_id );
|
||||||
|
|
||||||
|
if ( ! is_a( $request_data, 'WP_User_Request' ) || 'request-completed' !== $request_data->status ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$already_notified = (bool) get_post_meta( $request_id, '_wp_user_notified', true );
|
||||||
|
|
||||||
|
if ( $already_notified ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$subject = sprintf(
|
||||||
|
/* translators: %s Site name. */
|
||||||
|
__( '[%s] Erasure Request Fulfilled' ),
|
||||||
|
wp_specialchars_decode( get_option( 'blogname' ), ENT_QUOTES )
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filters the recipient of the data erasure fulfillment notification.
|
||||||
|
*
|
||||||
|
* @since 4.9.6
|
||||||
|
*
|
||||||
|
* @param string $user_email The email address of the notification recipient.
|
||||||
|
* @param WP_User_Request $request_data The request that is initiating the notification.
|
||||||
|
*/
|
||||||
|
$user_email = apply_filters( 'user_erasure_fulfillment_email_to', $request_data->email, $request_data );
|
||||||
|
|
||||||
|
$email_data = array(
|
||||||
|
'request' => $request_data,
|
||||||
|
'user_email' => $request_data->email,
|
||||||
|
'privacy_policy_url' => get_privacy_policy_url(),
|
||||||
|
'sitename' => get_option( 'blogname' ),
|
||||||
|
'siteurl' => home_url(),
|
||||||
|
);
|
||||||
|
|
||||||
|
if ( empty( $email_data['privacy_policy_url'] ) ) {
|
||||||
|
/* translators: Do not translate SITENAME, SITEURL; those are placeholders. */
|
||||||
|
$email_text = __(
|
||||||
|
'Howdy,
|
||||||
|
|
||||||
|
Your request to erase your personal data on ###SITENAME### has been completed.
|
||||||
|
|
||||||
|
If you have any follow-up questions or concerns, please contact the site administrator.
|
||||||
|
|
||||||
|
Regards,
|
||||||
|
All at ###SITENAME###
|
||||||
|
###SITEURL###'
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
/* translators: Do not translate SITENAME, SITEURL, PRIVACY_POLICY_URL; those are placeholders. */
|
||||||
|
$email_text = __(
|
||||||
|
'Howdy,
|
||||||
|
|
||||||
|
Your request to erase your personal data on ###SITENAME### has been completed.
|
||||||
|
|
||||||
|
If you have any follow-up questions or concerns, please contact the site administrator.
|
||||||
|
|
||||||
|
For more information, you can also read our privacy policy: ###PRIVACY_POLICY_URL###
|
||||||
|
|
||||||
|
Regards,
|
||||||
|
All at ###SITENAME###
|
||||||
|
###SITEURL###'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Filters the body of the data erasure fulfillment notification.
|
||||||
|
*
|
||||||
|
* The email is sent to a user when a their data erasure request is fulfilled
|
||||||
|
* by an administrator.
|
||||||
|
*
|
||||||
|
* The following strings have a special meaning and will get replaced dynamically:
|
||||||
|
*
|
||||||
|
* ###SITENAME### The name of the site.
|
||||||
|
* ###PRIVACY_POLICY_URL### Privacy policy page URL.
|
||||||
|
* ###SITEURL### The URL to the site.
|
||||||
|
*
|
||||||
|
* @since 4.9.6
|
||||||
|
*
|
||||||
|
* @param string $email_text Text in the email.
|
||||||
|
* @param array $email_data {
|
||||||
|
* Data relating to the account action email.
|
||||||
|
*
|
||||||
|
* @type WP_User_Request $request User request object.
|
||||||
|
* @type string $user_email The email address confirming a request.
|
||||||
|
* @type string $privacy_policy_url Privacy policy URL.
|
||||||
|
* @type string $sitename The site name sending the mail.
|
||||||
|
* @type string $siteurl The site URL sending the mail.
|
||||||
|
* }
|
||||||
|
*/
|
||||||
|
$content = apply_filters( 'user_confirmed_action_email_content', $email_text, $email_data );
|
||||||
|
|
||||||
|
$content = str_replace( '###SITENAME###', wp_specialchars_decode( $email_data['sitename'], ENT_QUOTES ), $content );
|
||||||
|
$content = str_replace( '###PRIVACY_POLICY_URL###', $email_data['privacy_policy_url'], $content );
|
||||||
|
$content = str_replace( '###SITEURL###', esc_url_raw( $email_data['siteurl'] ), $content );
|
||||||
|
|
||||||
|
$email_sent = wp_mail( $user_email, $subject, $content );
|
||||||
|
|
||||||
|
if ( $email_sent ) {
|
||||||
|
update_post_meta( $request_id, '_wp_user_notified', true );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return request confirmation message HTML.
|
* Return request confirmation message HTML.
|
||||||
*
|
*
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '4.9.6-beta1-43229';
|
$wp_version = '4.9.6-beta1-43231';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||||
|
Loading…
Reference in New Issue
Block a user