Make WordPress Core

Ticket #39119: 39119.2.diff

File 39119.2.diff, 7.5 KB (added by johnbillion, 7 years ago)
  • src/wp-admin/includes/ms-admin-filters.php

    diff --git a/src/wp-admin/includes/ms-admin-filters.php b/src/wp-admin/includes/ms-admin-filters.php
    index e8952e15b3..02fbf68b3c 100644
    a b add_action( 'network_admin_notices', 'site_admin_notice' ); 
    3838// Update Hooks
    3939add_action( 'network_admin_notices', 'update_nag',      3  );
    4040add_action( 'network_admin_notices', 'maintenance_nag', 10 );
     41
     42// Network Admin Hooks
     43add_action( 'add_site_option_new_admin_email',    'update_network_option_new_admin_email', 10, 2 );
     44add_action( 'update_site_option_new_admin_email', 'update_network_option_new_admin_email', 10, 2 );
  • src/wp-admin/network/settings.php

    diff --git a/src/wp-admin/network/settings.php b/src/wp-admin/network/settings.php
    index af37fbcbed..28330e0c4e 100644
    a b if ( ! current_user_can( 'manage_network_options' ) ) 
    1919$title = __( 'Network Settings' );
    2020$parent_file = 'settings.php';
    2121
     22// Handle network admin email change requests
     23if ( ! empty( $_GET[ 'network_admin_hash' ] ) ) {
     24        $new_admin_details = get_site_option( 'network_admin_hash' );
     25        $redirect = 'settings.php?updated=false';
     26        if ( is_array( $new_admin_details ) && hash_equals( $new_admin_details[ 'hash' ], $_GET[ 'network_admin_hash' ] ) && ! empty( $new_admin_details[ 'newemail' ] ) ) {
     27                update_site_option( 'admin_email', $new_admin_details[ 'newemail' ] );
     28                delete_site_option( 'network_admin_hash' );
     29                delete_site_option( 'new_admin_email' );
     30                $redirect = 'settings.php?updated=true';
     31        }
     32        wp_redirect( network_admin_url( $redirect ) );
     33        exit;
     34} elseif ( ! empty( $_GET['dismiss'] ) && 'new_network_admin_email' == $_GET['dismiss'] ) {
     35        check_admin_referer( 'dismiss_new_network_admin_email' );
     36        delete_site_option( 'network_admin_hash' );
     37        delete_site_option( 'new_admin_email' );
     38        wp_redirect( network_admin_url( 'settings.php?updated=true' ) );
     39        exit;
     40}
     41
    2242add_action( 'admin_head', 'network_settings_add_js' );
    2343
    2444get_current_screen()->add_help_tab( array(
    if ( $_POST ) { 
    5878                'upload_space_check_disabled', 'blog_upload_space', 'upload_filetypes', 'site_name',
    5979                'first_post', 'first_page', 'first_comment', 'first_comment_url', 'first_comment_author',
    6080                'welcome_email', 'welcome_user_email', 'fileupload_maxk', 'global_terms_enabled',
    61                 'illegal_names', 'limited_email_domains', 'banned_email_domains', 'WPLANG', 'admin_email',
     81                'illegal_names', 'limited_email_domains', 'banned_email_domains', 'WPLANG', 'new_admin_email',
    6282                'first_comment_email',
    6383        );
    6484
    if ( isset( $_GET['updated'] ) ) { 
    111131                        <tr>
    112132                                <th scope="row"><label for="admin_email"><?php _e( 'Network Admin Email' ) ?></label></th>
    113133                                <td>
    114                                         <input name="admin_email" type="email" id="admin_email" aria-describedby="admin-email-desc" class="regular-text" value="<?php echo esc_attr( get_site_option( 'admin_email' ) ) ?>" />
     134                                        <input name="new_admin_email" type="email" id="admin_email" aria-describedby="admin-email-desc" class="regular-text" value="<?php echo esc_attr( get_site_option( 'admin_email' ) ) ?>" />
    115135                                        <p class="description" id="admin-email-desc">
    116                                                 <?php _e( 'This email address will receive notifications. Registration and support emails will also come from this address.' ); ?>
     136                                                <?php _e( 'This address is used for admin purposes. If you change this we will send you an email at your new address to confirm it. <strong>The new address will not become active until confirmed.</strong>' ); ?>
    117137                                        </p>
     138                                        <?php
     139                                        $new_admin_email = get_site_option( 'new_admin_email' );
     140                                        if ( $new_admin_email && $new_admin_email != get_site_option( 'admin_email' ) ) : ?>
     141                                                <div class="updated inline">
     142                                                <p><?php
     143                                                        printf(
     144                                                                /* translators: %s: new network admin email */
     145                                                                __( 'There is a pending change of the network admin email to %s.' ),
     146                                                                '<code>' . esc_html( $new_admin_email ) . '</code>'
     147                                                        );
     148                                                        printf(
     149                                                                ' <a href="%1$s">%2$s</a>',
     150                                                                esc_url( wp_nonce_url( network_admin_url( 'settings.php?dismiss=new_network_admin_email' ), 'dismiss_new_network_admin_email' ) ),
     151                                                                __( 'Cancel' )
     152                                                        );
     153                                                ?></p>
     154                                                </div>
     155                                        <?php endif; ?>
    118156                                </td>
    119157                        </tr>
    120158                </table>
  • src/wp-includes/ms-functions.php

    diff --git a/src/wp-includes/ms-functions.php b/src/wp-includes/ms-functions.php
    index 03c376836a..53da005cf9 100644
    a b function get_subdirectory_reserved_names() { 
    26032603}
    26042604
    26052605/**
     2606 * Send a confirmation request email when a change of network admin email address is attempted.
     2607 *
     2608 * The new network admin address will not become active until confirmed.
     2609 *
     2610 * @since 4.9.0
     2611 *
     2612 * @param string $old_value The old network admin email address.
     2613 * @param string $value     The proposed new network admin email address.
     2614 */
     2615function update_network_option_new_admin_email( $old_value, $value ) {
     2616        if ( $value == get_site_option( 'admin_email' ) || ! is_email( $value ) ) {
     2617                return;
     2618        }
     2619
     2620        $hash = md5( $value . time() . mt_rand() );
     2621        $new_admin_email = array(
     2622                'hash'     => $hash,
     2623                'newemail' => $value,
     2624        );
     2625        update_site_option( 'network_admin_hash', $new_admin_email );
     2626
     2627        $switched_locale = switch_to_locale( get_user_locale() );
     2628
     2629        /* translators: Do not translate USERNAME, ADMIN_URL, EMAIL, SITENAME, SITEURL: those are placeholders. */
     2630        $email_text = __( 'Howdy ###USERNAME###,
     2631
     2632You recently requested to have the network admin email address on
     2633your network changed.
     2634
     2635If this is correct, please click on the following link to change it:
     2636###ADMIN_URL###
     2637
     2638You can safely ignore and delete this email if you do not want to
     2639take this action.
     2640
     2641This email has been sent to ###EMAIL###
     2642
     2643Regards,
     2644All at ###SITENAME###
     2645###SITEURL###' );
     2646
     2647        /**
     2648         * Filters the text of the email sent when a change of network admin email address is attempted.
     2649         *
     2650         * The following strings have a special meaning and will get replaced dynamically:
     2651         * ###USERNAME###  The current user's username.
     2652         * ###ADMIN_URL### The link to click on to confirm the email change.
     2653         * ###EMAIL###     The proposed new network admin email address.
     2654         * ###SITENAME###  The name of the network.
     2655         * ###SITEURL###   The URL to the network.
     2656         *
     2657         * @since 4.9.0
     2658         *
     2659         * @param string $email_text      Text in the email.
     2660         * @param array  $new_admin_email {
     2661         *     Data relating to the new network admin email address.
     2662         *
     2663         *     @type string $hash     The secure hash used in the confirmation link URL.
     2664         *     @type string $newemail The proposed new network admin email address.
     2665         * }
     2666         */
     2667        $content = apply_filters( 'new_network_admin_email_content', $email_text, $new_admin_email );
     2668
     2669        $current_user = wp_get_current_user();
     2670        $content = str_replace( '###USERNAME###', $current_user->user_login, $content );
     2671        $content = str_replace( '###ADMIN_URL###', esc_url( network_admin_url( 'settings.php?network_admin_hash=' . $hash ) ), $content );
     2672        $content = str_replace( '###EMAIL###', $value, $content );
     2673        $content = str_replace( '###SITENAME###', wp_specialchars_decode( get_site_option( 'site_name' ), ENT_QUOTES ), $content );
     2674        $content = str_replace( '###SITEURL###', network_home_url(), $content );
     2675
     2676        wp_mail( $value, sprintf( __( '[%s] New Network Admin Email Address' ), wp_specialchars_decode( get_site_option( 'site_name' ), ENT_QUOTES ) ), $content );
     2677
     2678        if ( $switched_locale ) {
     2679                restore_previous_locale();
     2680        }
     2681}
     2682
     2683/**
    26062684 * Send an email to the old network admin email address when the network admin email address changes.
    26072685 *
    26082686 * @since 4.9.0