mirror of
https://github.com/gosticks/wordpress-develop.git
synced 2026-06-28 14:20:15 +00:00
Privacy: Introduce filters for the headers of all the privacy-related e-mails:
* `wp_privacy_personal_data_email_headers` * `user_request_confirmed_email_headers` * `user_erasure_complete_email_headers` * `user_request_action_email_headers` Props xkon, garrett-eclipse, zaffarn, desrosj. Fixes #44501. git-svn-id: https://develop.svn.wordpress.org/trunk@47279 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
@@ -256,6 +256,38 @@ class Tests_Privacy_WpPrivacySendErasureFulfillmentNotification extends WP_UnitT
|
||||
return 'Modified text';
|
||||
}
|
||||
|
||||
/**
|
||||
* The email headers of the fulfillment notification should be filterable.
|
||||
*
|
||||
* @since 5.4.0
|
||||
*
|
||||
* @ticket 44501
|
||||
*/
|
||||
public function test_email_headers_should_be_filterable() {
|
||||
add_filter( 'user_erasure_complete_email_headers', array( $this, 'modify_email_headers' ) );
|
||||
_wp_privacy_send_erasure_fulfillment_notification( self::$request_id );
|
||||
|
||||
$mailer = tests_retrieve_phpmailer_instance();
|
||||
|
||||
$this->assertContains( 'From: Tester <tester@example.com>', $mailer->get_sent()->header );
|
||||
}
|
||||
|
||||
/**
|
||||
* Filter callback that modifies the email headers of the data erasure fulfillment notification.
|
||||
*
|
||||
* @since 5.4.0
|
||||
*
|
||||
* @param string|array $headers The email headers.
|
||||
* @return array $headers The new email headers.
|
||||
*/
|
||||
public function modify_email_headers( $headers ) {
|
||||
$headers = array(
|
||||
'From: Tester <tester@example.com>',
|
||||
);
|
||||
|
||||
return $headers;
|
||||
}
|
||||
|
||||
/**
|
||||
* The function should not send an email when the request ID does not exist.
|
||||
*
|
||||
|
||||
@@ -252,6 +252,38 @@ class Tests_Privacy_WpPrivacySendPersonalDataExportEmail extends WP_UnitTestCase
|
||||
return 'Custom content for request ID: ' . $request_id;
|
||||
}
|
||||
|
||||
/**
|
||||
* The email headers should be filterable.
|
||||
*
|
||||
* @since 5.4.0
|
||||
*
|
||||
* @ticket 44501
|
||||
*/
|
||||
public function test_email_headers_should_be_filterable() {
|
||||
add_filter( 'wp_privacy_personal_data_email_headers', array( $this, 'modify_email_headers' ) );
|
||||
wp_privacy_send_personal_data_export_email( self::$request_id );
|
||||
|
||||
$mailer = tests_retrieve_phpmailer_instance();
|
||||
|
||||
$this->assertContains( 'From: Tester <tester@example.com>', $mailer->get_sent()->header );
|
||||
}
|
||||
|
||||
/**
|
||||
* Filter callback to modify the headers of the email sent with a personal data export file.
|
||||
*
|
||||
* @since 5.4.0
|
||||
*
|
||||
* @param string|array $headers The email headers.
|
||||
* @return array $headers The new email headers.
|
||||
*/
|
||||
public function modify_email_headers( $headers ) {
|
||||
$headers = array(
|
||||
'From: Tester <tester@example.com>',
|
||||
);
|
||||
|
||||
return $headers;
|
||||
}
|
||||
|
||||
/**
|
||||
* The email content should be filterable using the $email_data
|
||||
*
|
||||
|
||||
@@ -207,4 +207,42 @@ class Tests_User_WpPrivacySendRequestConfirmationNotification extends WP_UnitTes
|
||||
return $email_text;
|
||||
}
|
||||
|
||||
/**
|
||||
* The email headers should be filterable.
|
||||
*
|
||||
* @since 5.4.0
|
||||
*
|
||||
* @ticket 44501
|
||||
*/
|
||||
public function test_email_headers_should_be_filterable() {
|
||||
$email = 'export.request.from.unregistered.user@example.com';
|
||||
$request_id = wp_create_user_request( $email, 'export_personal_data' );
|
||||
|
||||
_wp_privacy_account_request_confirmed( $request_id );
|
||||
|
||||
add_filter( 'user_request_confirmed_email_headers', array( $this, 'modify_email_headers' ) );
|
||||
_wp_privacy_send_request_confirmation_notification( $request_id );
|
||||
remove_filter( 'user_request_confirmed_email_headers', array( $this, 'modify_email_headers' ) );
|
||||
|
||||
$mailer = tests_retrieve_phpmailer_instance();
|
||||
|
||||
$this->assertContains( 'From: Tester <tester@example.com>', $mailer->get_sent()->header );
|
||||
}
|
||||
|
||||
/**
|
||||
* Filter callback that modifies the headers of the user request confirmation email.
|
||||
*
|
||||
* @since 5.4.0
|
||||
*
|
||||
* @param string|array $headers The email headers.
|
||||
* @return array $headers The new email headers.
|
||||
*/
|
||||
public function modify_email_headers( $headers ) {
|
||||
$headers = array(
|
||||
'From: Tester <tester@example.com>',
|
||||
);
|
||||
|
||||
return $headers;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -1798,6 +1798,8 @@ class Tests_User extends WP_UnitTestCase {
|
||||
/**
|
||||
* Testing the `wp_privacy_additional_user_profile_data` filter works.
|
||||
*
|
||||
* @since 5.4.0
|
||||
*
|
||||
* @ticket 47509
|
||||
*/
|
||||
function test_filter_wp_privacy_additional_user_profile_data() {
|
||||
@@ -1881,6 +1883,8 @@ class Tests_User extends WP_UnitTestCase {
|
||||
/**
|
||||
* Filter callback to add additional profile data to the User Group on Export Requests.
|
||||
*
|
||||
* @since 5.4.0
|
||||
*
|
||||
* @ticket 47509
|
||||
*
|
||||
* @return array $additional_profile_data The additional user data.
|
||||
@@ -1902,6 +1906,8 @@ class Tests_User extends WP_UnitTestCase {
|
||||
*
|
||||
* This callback should generate a `_doing_it_wrong()`.
|
||||
*
|
||||
* @since 5.4.0
|
||||
*
|
||||
* @ticket 47509
|
||||
*
|
||||
* @return array $additional_profile_data The additional user data.
|
||||
|
||||
@@ -228,6 +228,40 @@ class Tests_User_WpSendUserRequest extends WP_UnitTestCase {
|
||||
return 'Custom Email Content.';
|
||||
}
|
||||
|
||||
/**
|
||||
* The email headers should be filterable.
|
||||
*
|
||||
* @since 5.4.0
|
||||
*
|
||||
* @ticket 44501
|
||||
*/
|
||||
public function test_email_headers_should_be_filterable() {
|
||||
$request_id = wp_create_user_request( self::$test_user->user_email, 'remove_personal_data' );
|
||||
|
||||
add_filter( 'user_request_action_email_headers', array( $this, 'modify_email_headers' ) );
|
||||
$result = wp_send_user_request( $request_id );
|
||||
|
||||
$mailer = tests_retrieve_phpmailer_instance();
|
||||
|
||||
$this->assertContains( 'From: Tester <tester@example.com>', $mailer->get_sent()->header );
|
||||
}
|
||||
|
||||
/**
|
||||
* Filter callback to modify the headers of the email sent when an account action is attempted.
|
||||
*
|
||||
* @since 5.4.0
|
||||
*
|
||||
* @param string|array $headers The email headers.
|
||||
* @return array $headers The new email headers.
|
||||
*/
|
||||
public function modify_email_headers( $headers ) {
|
||||
$headers = array(
|
||||
'From: Tester <tester@example.com>',
|
||||
);
|
||||
|
||||
return $headers;
|
||||
}
|
||||
|
||||
/**
|
||||
* The function should error when the email was not sent.
|
||||
*
|
||||
|
||||
Reference in New Issue
Block a user