WordPress.org

Make WordPress Core

Ticket #4793: 4793.diff

File 4793.diff, 6.3 KB (added by Nazgul, 11 years ago)
  • wp-includes/pluggable.php

     
    157157endif;
    158158
    159159if ( !function_exists( 'wp_mail' ) ) :
    160 function wp_mail($to, $subject, $message, $headers = '') {
     160function wp_mail( $to, $subject, $message, $headers = '' ) {
    161161        global $phpmailer;
    162162
    163         if ( !is_object( $phpmailer ) ) {
    164                 require_once(ABSPATH . WPINC . '/class-phpmailer.php');
    165                 require_once(ABSPATH . WPINC . '/class-smtp.php');
     163        // (Re)create it, if it's gone missing
     164        if ( !is_object( $phpmailer ) || !is_a( $phpmailer, 'PHPMailer' ) ) {
     165                require_once ABSPATH . WPINC . '/class-phpmailer.php';
     166                require_once ABSPATH . WPINC . '/class-smtp.php';
    166167                $phpmailer = new PHPMailer();
    167168        }
    168169
    169         $mail = compact('to', 'subject', 'message', 'headers');
    170         $mail = apply_filters('wp_mail', $mail);
    171         extract($mail, EXTR_SKIP);
     170        // Compact the input, apply the filters, and extract them back out
     171        extract( apply_filters( 'wp_mail', compact( 'to', 'subject', 'message', 'headers' ) ), EXTR_SKIP );
    172172
    173         if ( $headers == '' ) {
    174                 $headers = "MIME-Version: 1.0\n" .
    175                         "From: " . apply_filters('wp_mail_from', "wordpress@" . preg_replace('#^www\.#', '', strtolower($_SERVER['SERVER_NAME']))) . "\n" .
    176                         "Content-Type: text/plain; charset=\"" . get_option('blog_charset') . "\"\n";
     173        // Headers
     174        if ( empty( $headers ) ) {
     175                $headers = array();
     176        } elseif ( !is_array( $headers ) ) {
     177                // Explode the headers out, so this function can take both
     178                // string headers and an array of headers.
     179                $tempheaders = (array) explode( "\n", $headers );
     180                $headers = array();
     181
     182                // If it's actually got contents
     183                if ( !empty( $tempheaders ) ) {
     184                        // Iterate through the raw headers
     185                        foreach ( $tempheaders as $header ) {
     186                                if ( strpos($header, ':') === false )
     187                                        continue;
     188                                // Explode them out
     189                                list( $name, $content ) = explode( ':', trim( $header ), 2 );
     190
     191                                // Cleanup crew
     192                                $name = trim( $name );
     193                                $content = trim( $content );
     194
     195                                // Mainly for legacy -- process a From: header if it's there
     196                                if ( 'from' == strtolower($name) ) {
     197                                        if ( strpos($content, '<' ) !== false ) {
     198                                                // So... making my life hard again?
     199                                                $from_name = substr( $content, 0, strpos( $content, '<' ) - 1 );
     200                                                $from_name = str_replace( '"', '', $from_name );
     201                                                $from_name = trim( $from_name );
     202
     203                                                $from_email = substr( $content, strpos( $content, '<' ) + 1 );
     204                                                $from_email = str_replace( '>', '', $from_email );
     205                                                $from_email = trim( $from_email );
     206                                        } else {
     207                                                $from_name = trim( $content );
     208                                        }
     209                                } elseif ( 'content-type' == strtolower($name) ) {
     210                                        if ( strpos( $content,';' ) !== false ) {
     211                                                list( $type, $charset ) = explode( ';', $content );
     212                                                $content_type = trim( $type );
     213                                                $charset = trim( str_replace( array( 'charset=', '"' ), '', $charset ) );
     214                                        } else {
     215                                                $content_type = trim( $content );
     216                                        }
     217                                } else {
     218                                        // Add it to our grand headers array
     219                                        $headers[trim( $name )] = trim( $content );
     220                                }
     221                        }
     222                }
    177223        }
    178224
     225        // Empty out the values that may be set
    179226        $phpmailer->ClearAddresses();
     227        $phpmailer->ClearAllRecipients();
     228        $phpmailer->ClearAttachments();
     229        $phpmailer->ClearBCCs();
    180230        $phpmailer->ClearCCs();
    181         $phpmailer->ClearBCCs();
     231        $phpmailer->ClearCustomHeaders();
    182232        $phpmailer->ClearReplyTos();
    183         $phpmailer->ClearAllRecipients();
    184         $phpmailer->ClearCustomHeaders();
    185233
    186         $phpmailer->FromName = "WordPress";
    187         $phpmailer->AddAddress("$to", "");
     234        // From email and name
     235        // If we don't have a name from the input headers
     236        if ( !isset( $from_name ) ) {
     237                $from_name = 'WordPress';
     238        }
     239
     240        // If we don't have an email from the input headers
     241        if ( !isset( $from_email ) ) {
     242                // Get the site domain and get rid of www.
     243                $sitename = strtolower( $_SERVER['SERVER_NAME'] );
     244                if ( substr( $sitename, 0, 4 ) == 'www.' ) {
     245                        $sitename = substr( $sitename, 4 );
     246                }
     247
     248                $from_email = 'wordpress@' . $sitename;
     249        }
     250
     251        // Set the from name and email
     252        $phpmailer->From = apply_filters( 'wp_mail_from', $from_email );
     253        $phpmailer->FromName = apply_filters( 'wp_mail_from_name', $from_name );
     254
     255        // Set destination address
     256        $phpmailer->AddAddress( $to );
     257
     258        // Set mail's subject and body
    188259        $phpmailer->Subject = $subject;
    189         $phpmailer->Body    = $message;
    190         $phpmailer->IsHTML(false);
    191         $phpmailer->IsMail(); // set mailer to use php mail()
     260        $phpmailer->Body = $message;
    192261
    193         do_action_ref_array('phpmailer_init', array(&$phpmailer));
     262        // Set to use PHP's mail()
     263        $phpmailer->IsMail();
    194264
    195         $mailheaders = (array) explode( "\n", $headers );
    196         foreach ( $mailheaders as $line ) {
    197                 $header = explode( ":", $line );
    198                 switch ( trim( $header[0] ) ) {
    199                         case "From":
    200                                 $from = trim( str_replace( '"', '', $header[1] ) );
    201                                 if ( strpos( $from, '<' ) ) {
    202                                         $phpmailer->FromName = str_replace( '"', '', substr( $header[1], 0, strpos( $header[1], '<' ) - 1 ) );
    203                                         $from = trim( substr( $from, strpos( $from, '<' ) + 1 ) );
    204                                         $from = str_replace( '>', '', $from );
    205                                 } else {
    206                                         $phpmailer->FromName = $from;
    207                                 }
    208                                 $phpmailer->From = trim( $from );
    209                                 break;
    210                         default:
    211                                 if ( $line != '' && $header[0] != 'MIME-Version' && $header[0] != 'Content-Type' )
    212                                         $phpmailer->AddCustomHeader( $line );
    213                                 break;
     265        // Set Content-Type and charset
     266        // If we don't have a content-type from the input headers
     267        if ( !isset( $content_type ) ) {
     268                $content_type = 'text/plain';
     269        }
     270
     271        $content_type = apply_filters( 'wp_mail_content_type', $content_type );
     272
     273        // Set whether it's plaintext or not, depending on $content_type
     274        if ( $content_type == 'text/html' ) {
     275                $phpmailer->IsHTML( true );
     276        } else {
     277                $phpmailer->IsHTML( false );
     278        }
     279
     280        // If we don't have a charset from the input headers
     281        if ( !isset( $charset ) ) {
     282                $charset = get_bloginfo( 'charset' );
     283        }
     284
     285        // Set the content-type and charset
     286        $phpmailer->CharSet = apply_filters( 'wp_mail_charset', $charset );
     287
     288        // Set custom headers
     289        if ( !empty( $headers ) ) {
     290                foreach ( $headers as $name => $content ) {
     291                        $phpmailer->AddCustomHeader( sprintf( '%1$s: %2$s', $name, $content ) );
    214292                }
    215293        }
    216294
     295        do_action_ref_array( 'phpmailer_init', array( &$phpmailer ) );
     296
     297        // Send!
    217298        $result = @$phpmailer->Send();
    218299
    219300        return $result;