Upgrade/Install: Pass details about the specific plugin and theme updates attempted to filters.

This adds an additional parameter to the `auto_plugin_update_send_email` and `auto_theme_update_send_email` filters to provide the additional context of which updates were attempted and their outcome. This will help plugin and theme auto-update emails to be better tailored to a site owner's liking.

Props audrasjb, Paddy Landau, desrosj.
Merges [48888] to the 5.5 branch.
Fixes #50988.
Built from https://develop.svn.wordpress.org/branches/5.5@48889


git-svn-id: http://core.svn.wordpress.org/branches/5.5@48651 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
desrosj 2020-08-27 19:34:05 +00:00
parent 8096a67b7c
commit 9fceb56948
2 changed files with 10 additions and 6 deletions

View File

@ -879,7 +879,7 @@ class WP_Automatic_Updater {
* *
* @since 5.5.0 * @since 5.5.0
* *
* @param array $update_results The result of updates tasks. * @param array $update_results The results of update tasks.
*/ */
protected function after_plugin_theme_update( $update_results ) { protected function after_plugin_theme_update( $update_results ) {
$successful_updates = array(); $successful_updates = array();
@ -889,10 +889,12 @@ class WP_Automatic_Updater {
* Filters whether to send an email following an automatic background plugin update. * Filters whether to send an email following an automatic background plugin update.
* *
* @since 5.5.0 * @since 5.5.0
* @since 5.5.1 Added the $update_results parameter.
* *
* @param bool $enabled True if plugins notifications are enabled, false otherwise. * @param bool $enabled True if plugins notifications are enabled, false otherwise.
* @param array $update_results The results of plugins update tasks.
*/ */
$notifications_enabled = apply_filters( 'auto_plugin_update_send_email', true ); $notifications_enabled = apply_filters( 'auto_plugin_update_send_email', true, $update_results['plugin'] );
if ( ! empty( $update_results['plugin'] ) && $notifications_enabled ) { if ( ! empty( $update_results['plugin'] ) && $notifications_enabled ) {
foreach ( $update_results['plugin'] as $update_result ) { foreach ( $update_results['plugin'] as $update_result ) {
@ -908,10 +910,12 @@ class WP_Automatic_Updater {
* Filters whether to send an email following an automatic background theme update. * Filters whether to send an email following an automatic background theme update.
* *
* @since 5.5.0 * @since 5.5.0
* @since 5.5.1 Added the $update_results parameter.
* *
* @param bool $enabled True if notifications are enabled, false otherwise. * @param bool $enabled True if notifications are enabled, false otherwise.
* @param array $update_results The results of theme update tasks.
*/ */
$notifications_enabled = apply_filters( 'auto_theme_update_send_email', true ); $notifications_enabled = apply_filters( 'auto_theme_update_send_email', true, $update_results['theme'] );
if ( ! empty( $update_results['theme'] ) && $notifications_enabled ) { if ( ! empty( $update_results['theme'] ) && $notifications_enabled ) {
foreach ( $update_results['theme'] as $update_result ) { foreach ( $update_results['theme'] as $update_result ) {

View File

@ -13,7 +13,7 @@
* *
* @global string $wp_version * @global string $wp_version
*/ */
$wp_version = '5.5.1-alpha-48887'; $wp_version = '5.5.1-alpha-48889';
/** /**
* 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.