Administration: Improve the plugin and theme auto-update emails.

This makes several improvements to the emails sent to site admins when plugin and theme auto-updates are attempted.

- Emails are now specifically tailored to the three results (success, failed, or mixed).
- Subject lines and body copy for mixed and failed results now correctly convey the importance of double checking the site in question.
- The site’s URL is now included in all emails.
- When failures occur, links to the Plugins and/or Themes pages in the admin are now included so that site owners can easily take action.

Props audrasjb, desrosj, azaozz, garrett-eclipse, paaljoachim, johnbillion, marybaum, pbiron.
Follow up to [47835].
See #50052.
Fixes #50268.
Built from https://develop.svn.wordpress.org/trunk@48123


git-svn-id: http://core.svn.wordpress.org/trunk@47892 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
desrosj 2020-06-22 18:18:08 +00:00
parent acc97eae32
commit 35545bee43
2 changed files with 122 additions and 56 deletions

View File

@ -940,75 +940,141 @@ class WP_Automatic_Updater {
if ( empty( $successful_updates ) && empty( $failed_updates ) ) { if ( empty( $successful_updates ) && empty( $failed_updates ) ) {
return; return;
} }
$body = array(); $body = array();
$successful_plugins = ( ! empty( $successful_updates['plugin'] ) );
$successful_themes = ( ! empty( $successful_updates['theme'] ) );
$failed_plugins = ( ! empty( $failed_updates['plugin'] ) );
$failed_themes = ( ! empty( $failed_updates['theme'] ) );
switch ( $type ) { switch ( $type ) {
case 'success': case 'success':
if ( $successful_plugins && $successful_themes ) {
/* translators: %s: Site title. */ /* translators: %s: Site title. */
$subject = __( '[%s] Some plugins or themes were automatically updated' ); $subject = __( '[%s] Some plugins and themes have automatically updated' );
$body[] = sprintf(
/* translators: %s: Home URL. */
__( 'Howdy! Some plugins and themes have automatically updated to their latest versions on your site at %s. No further action is needed on your part.' ),
home_url()
);
} elseif ( $successful_plugins ) {
/* translators: %s: Site title. */
$subject = __( '[%s] Some plugins were automatically updated' );
$body[] = sprintf(
/* translators: %s: Home URL. */
__( 'Howdy! Some plugins have automatically updated to their latest versions on your site at %s. No further action is needed on your part.' ),
home_url()
);
} else {
/* translators: %s: Site title. */
$subject = __( '[%s] Some themes were automatically updated' );
$body[] = sprintf(
/* translators: %s: Home URL. */
__( 'Howdy! Some themes have automatically updated to their latest versions on your site at %s. No further action is needed on your part.' ),
home_url()
);
}
break; break;
case 'fail': case 'fail':
/* translators: %s: Site title. */
$subject = __( '[%s] Some plugins or themes have failed to update' );
$body[] = sprintf(
/* translators: %s: Home URL. */
__( 'Howdy! Failures occurred when attempting to update plugins/themes on your site at %s.' ),
home_url()
);
$body[] = "\n";
$body[] = __( 'Please check out your site now. Its possible that everything is working. If it says you need to update, you should do so.' );
break;
case 'mixed': case 'mixed':
if ( $failed_plugins && $failed_themes ) {
/* translators: %s: Site title. */ /* translators: %s: Site title. */
$subject = __( '[%s] Some plugins or themes were automatically updated' ); $subject = __( '[%s] Some plugins and themes have failed to update' );
$body[] = sprintf( $body[] = sprintf(
/* translators: %s: Home URL. */ /* translators: %s: Home URL. */
__( 'Howdy! Failures occurred when attempting to update plugins/themes on your site at %s.' ), __( 'Howdy! Plugins and themes failed to update on your site at %s.' ),
home_url() home_url()
); );
$body[] = "\n"; } elseif ( $failed_plugins ) {
$body[] = __( 'Please check out your site now. Its possible that everything is working. If it says you need to update, you should do so.' ); /* translators: %s: Site title. */
$body[] = "\n"; $subject = __( '[%s] Some plugins have failed to update' );
$body[] = sprintf(
/* translators: %s: Home URL. */
__( 'Howdy! Plugins failed to update on your site at %s.' ),
home_url()
);
} else {
/* translators: %s: Site title. */
$subject = __( '[%s] Some themes have failed to update' );
$body[] = sprintf(
/* translators: %s: Home URL. */
__( 'Howdy! Themes failed to update on your site at %s.' ),
home_url()
);
}
break; break;
} }
// Get failed plugin updates. if ( in_array( $type, array( 'fail', 'mixed' ), true ) ) {
if ( in_array( $type, array( 'fail', 'mixed' ), true ) && ! empty( $failed_updates['plugin'] ) ) { $body[] = "\n";
$body[] = __( 'The following plugins failed to update:' ); $body[] = __( 'Please check your site now. Its possible that everything is working. If there are updates available, you should update.' );
// List failed updates. $body[] = "\n";
// List failed plugin updates.
if ( ! empty( $failed_updates['plugin'] ) ) {
$body[] = __( 'These plugins failed to update:' );
foreach ( $failed_updates['plugin'] as $item ) { foreach ( $failed_updates['plugin'] as $item ) {
$body[] = "- {$item->name}"; $body[] = "- {$item->name}";
} }
$body[] = "\n"; $body[] = "\n";
} }
// Get failed theme updates.
if ( in_array( $type, array( 'fail', 'mixed' ), true ) && ! empty( $failed_updates['theme'] ) ) { // List failed theme updates.
$body[] = __( 'The following themes failed to update:' ); if ( ! empty( $failed_updates['theme'] ) ) {
// List failed updates. $body[] = __( 'These themes failed to update:' );
foreach ( $failed_updates['theme'] as $item ) { foreach ( $failed_updates['theme'] as $item ) {
$body[] = "- {$item->name}"; $body[] = "- {$item->name}";
} }
$body[] = "\n"; $body[] = "\n";
} }
// Get successful plugin updates. }
if ( in_array( $type, array( 'success', 'mixed' ), true ) && ! empty( $successful_updates['plugin'] ) ) {
$body[] = __( 'The following plugins were successfully updated:' );
// List successful updates. // List successful updates.
if ( in_array( $type, array( 'success', 'mixed' ), true ) ) {
$body[] = "\n";
// List successful plugin updates.
if ( ! empty( $successful_updates['plugin'] ) ) {
$body[] = __( 'These plugins are now up to date:' );
foreach ( $successful_updates['plugin'] as $item ) { foreach ( $successful_updates['plugin'] as $item ) {
$body[] = "- {$item->name}"; $body[] = "- {$item->name}";
} }
$body[] = "\n"; $body[] = "\n";
} }
// Get successful theme updates.
if ( in_array( $type, array( 'success', 'mixed' ), true ) && ! empty( $successful_updates['theme'] ) ) { // List successful theme updates.
$body[] = __( 'The following themes were successfully updated:' ); if ( ! empty( $successful_updates['theme'] ) ) {
$body[] = __( 'These themes are now up to date:' );
// List successful updates. // List successful updates.
foreach ( $successful_updates['theme'] as $item ) { foreach ( $successful_updates['theme'] as $item ) {
$body[] = "- {$item->name}"; $body[] = "- {$item->name}";
} }
$body[] = "\n"; $body[] = "\n";
} }
}
if ( $failed_plugins ) {
$body[] = sprintf(
/* translators: %s: Plugins screen URL. */
__( 'To manage plugins on your site, visit the Plugins page: %s' ),
admin_url( 'plugins.php' )
);
$body[] = "\n"; $body[] = "\n";
}
if ( $failed_themes ) {
$body[] = sprintf(
/* translators: %s: Themes screen URL. */
__( 'To manage themes on your site, visit the Themes page: %s' ),
admin_url( 'themes.php' )
);
$body[] = "\n";
}
// Add a note about the support forums. // Add a note about the support forums.
$body[] = __( 'If you experience any issues or need support, the volunteers in the WordPress.org support forums may be able to help.' ); $body[] = __( 'If you experience any issues or need support, the volunteers in the WordPress.org support forums may be able to help.' );

View File

@ -13,7 +13,7 @@
* *
* @global string $wp_version * @global string $wp_version
*/ */
$wp_version = '5.5-alpha-48122'; $wp_version = '5.5-alpha-48123';
/** /**
* 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.