diff --git wp-admin/includes/schema.php wp-admin/includes/schema.php index 037210a..a5e896b 100644 --- wp-admin/includes/schema.php +++ wp-admin/includes/schema.php @@ -373,10 +373,6 @@ function populate_options() { 'comments_notify' => 1, 'posts_per_rss' => 10, 'rss_use_excerpt' => 0, - 'mailserver_url' => 'mail.example.com', - 'mailserver_login' => 'login@example.com', - 'mailserver_pass' => 'password', - 'mailserver_port' => 110, 'default_category' => 1, 'default_comment_status' => 'open', 'default_ping_status' => 'open', @@ -480,6 +476,9 @@ function populate_options() { // 3.5 'link_manager_enabled' => 0, + + // 3.7 + 'post_by_email_enabled' => 0, ); // 3.3 diff --git wp-admin/includes/upgrade.php wp-admin/includes/upgrade.php index cfbaac8..354cb6f 100644 --- wp-admin/includes/upgrade.php +++ wp-admin/includes/upgrade.php @@ -402,10 +402,15 @@ function upgrade_all() { if ( $wp_current_db_version < 22422 ) upgrade_350(); + if ( $wp_current_db_version < 25448 ) + upgrade_370(); + maybe_disable_link_manager(); maybe_disable_automattic_widgets(); + maybe_disable_post_by_email(); + update_option( 'db_version', $wp_db_version ); update_option( 'db_upgraded', true ); } @@ -1209,6 +1214,18 @@ function upgrade_350() { } /** + * Execute changes made in WordPress 3.7. + * + * @since 3.7.0 + */ +function upgrade_370() { + global $wp_current_db_version; + + if ( $wp_current_db_version < 25134 && 'mail.example.com' != get_option( 'mailserver_url' ) ) + update_option( 'post_by_email_enabled', 1 ); // Previously set to 0 by populate_options() +} + +/** * Execute network level changes * * @since 3.0.0 @@ -1959,6 +1976,18 @@ function maybe_disable_link_manager() { } /** + * Disables Post by Email options if, at the time of upgrade, the settings have not been changed from original defaults. + * + * @since 3.7.0 + */ +function maybe_disable_post_by_email() { + global $wp_current_db_version; + + if ( $wp_current_db_version >= 25448 && get_option( 'post_by_email_enabled' ) && 'mail.example.com' == get_option( 'mailserver_url' ) ) + update_option( 'post_by_email_enabled', 0 ); +} + +/** * Runs before the schema is upgraded. * * @since 2.9.0 diff --git wp-admin/options-writing.php wp-admin/options-writing.php index 87fbf53..4202ef6 100644 --- wp-admin/options-writing.php +++ wp-admin/options-writing.php @@ -28,15 +28,6 @@ get_current_screen()->add_help_tab( array( 'content' => '
' . __('Press This is a bookmarklet that makes it easy to blog about something you come across on the web. You can use it to just grab a link, or to post an excerpt. Press This will even allow you to choose from images included on the page and use them in your post. Just drag the Press This link on this screen to your bookmarks bar in your browser, and you’ll be on your way to easier content creation. Clicking on it while on another website opens a popup window with all these options.') . '
', ) ); -//duplicate_hook -if ( apply_filters( 'enable_post_by_email_configuration', true ) ) { - get_current_screen()->add_help_tab( array( - 'id' => 'options-postemail', - 'title' => __( 'Post Via Email' ), - 'content' => '' . __( 'Post via email settings allow you to send your WordPress install an email with the content of your post. You must set up a secret e-mail account with POP3 access to use this, and any mail received at this address will be posted, so it’s a good idea to keep this address very secret.' ) . '
', - ) ); -} - /** * Toggle site update services configuration functionality. * @@ -132,39 +123,9 @@ do_settings_fields('writing', 'remote_publishing'); // A deprecated section. - -%s, %s, %s.'), wp_generate_password(8, false), wp_generate_password(8, false), wp_generate_password(8, false)) ?>
- -| - | - - - | -
|---|---|
| - | - |
| - | - - | -
| - | - 0, 'name' => 'default_email_category', 'orderby' => 'name', 'selected' => get_option('default_email_category'), 'hierarchical' => true)); -?> - | -
Post By Email plugin.' ); ?>
Writing + * This file is deprecated and has been replaced by the + * plugin Post By Email. Instead of loading wp-mail.php to + * trigger the "wp-mail.php" action, you should trigger it + * yourself, either in a plugin/theme hook or via wp_cron. + * + * For more information: + * http://wordpress.org/plugins/post-by-email/ + * http://codex.wordpress.org/Category:WP-Cron_Functions * * @package WordPress */ @@ -10,221 +15,7 @@ /** Make sure that the WordPress bootstrap has run before continuing. */ require(dirname(__FILE__) . '/wp-load.php'); -if ( ! apply_filters( 'enable_post_by_email_configuration', true ) ) - wp_die( __( 'This action has been disabled by the administrator.' ) ); +_doing_it_wrong( 'wp-mail.php', __( "This file is deprecated and should not be called directly. Schedule the action 'wp-mail.php' instead." ), '3.7' ); /** Allow a plugin to do a complete takeover of Post by Email **/ -do_action('wp-mail.php'); - -/** Get the POP3 class with which to access the mailbox. */ -require_once( ABSPATH . WPINC . '/class-pop3.php' ); - -/** Only check at this interval for new messages. */ -if ( !defined('WP_MAIL_INTERVAL') ) - define('WP_MAIL_INTERVAL', 300); // 5 minutes - -$last_checked = get_transient('mailserver_last_checked'); - -if ( $last_checked ) - wp_die(__('Slow down cowboy, no need to check for new mails so often!')); - -set_transient('mailserver_last_checked', true, WP_MAIL_INTERVAL); - -$time_difference = get_option('gmt_offset') * HOUR_IN_SECONDS; - -$phone_delim = '::'; - -$pop3 = new POP3(); - -if ( !$pop3->connect( get_option('mailserver_url'), get_option('mailserver_port') ) || !$pop3->user( get_option('mailserver_login') ) ) - wp_die( esc_html( $pop3->ERROR ) ); - -$count = $pop3->pass( get_option('mailserver_pass') ); - -if( false === $count ) - wp_die( esc_html( $pop3->ERROR ) ); - -if( 0 === $count ) { - $pop3->quit(); - wp_die( __('There doesn’t seem to be any new mail.') ); -} - -for ( $i = 1; $i <= $count; $i++ ) { - - $message = $pop3->get($i); - - $bodysignal = false; - $boundary = ''; - $charset = ''; - $content = ''; - $content_type = ''; - $content_transfer_encoding = ''; - $post_author = 1; - $author_found = false; - $dmonths = array('Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'); - foreach ($message as $line) { - // body signal - if ( strlen($line) < 3 ) - $bodysignal = true; - if ( $bodysignal ) { - $content .= $line; - } else { - if ( preg_match('/Content-Type: /i', $line) ) { - $content_type = trim($line); - $content_type = substr($content_type, 14, strlen($content_type) - 14); - $content_type = explode(';', $content_type); - if ( ! empty( $content_type[1] ) ) { - $charset = explode('=', $content_type[1]); - $charset = ( ! empty( $charset[1] ) ) ? trim($charset[1]) : ''; - } - $content_type = $content_type[0]; - } - if ( preg_match('/Content-Transfer-Encoding: /i', $line) ) { - $content_transfer_encoding = trim($line); - $content_transfer_encoding = substr($content_transfer_encoding, 27, strlen($content_transfer_encoding) - 27); - $content_transfer_encoding = explode(';', $content_transfer_encoding); - $content_transfer_encoding = $content_transfer_encoding[0]; - } - if ( ( $content_type == 'multipart/alternative' ) && ( false !== strpos($line, 'boundary="') ) && ( '' == $boundary ) ) { - $boundary = trim($line); - $boundary = explode('"', $boundary); - $boundary = $boundary[1]; - } - if (preg_match('/Subject: /i', $line)) { - $subject = trim($line); - $subject = substr($subject, 9, strlen($subject) - 9); - // Captures any text in the subject before $phone_delim as the subject - if ( function_exists('iconv_mime_decode') ) { - $subject = iconv_mime_decode($subject, 2, get_option('blog_charset')); - } else { - $subject = wp_iso_descrambler($subject); - } - $subject = explode($phone_delim, $subject); - $subject = $subject[0]; - } - - // Set the author using the email address (From or Reply-To, the last used) - // otherwise use the site admin - if ( ! $author_found && preg_match( '/^(From|Reply-To): /', $line ) ) { - if ( preg_match('|[a-z0-9_.-]+@[a-z0-9_.-]+(?!.*<)|i', $line, $matches) ) - $author = $matches[0]; - else - $author = trim($line); - $author = sanitize_email($author); - if ( is_email($author) ) { - echo '' . sprintf(__('Author is %s'), $author) . '
'; - $userdata = get_user_by('email', $author); - if ( ! empty( $userdata ) ) { - $post_author = $userdata->ID; - $author_found = true; - } - } - } - - if (preg_match('/Date: /i', $line)) { // of the form '20 Mar 2002 20:32:37' - $ddate = trim($line); - $ddate = str_replace('Date: ', '', $ddate); - if (strpos($ddate, ',')) { - $ddate = trim(substr($ddate, strpos($ddate, ',') + 1, strlen($ddate))); - } - $date_arr = explode(' ', $ddate); - $date_time = explode(':', $date_arr[3]); - - $ddate_H = $date_time[0]; - $ddate_i = $date_time[1]; - $ddate_s = $date_time[2]; - - $ddate_m = $date_arr[1]; - $ddate_d = $date_arr[0]; - $ddate_Y = $date_arr[2]; - for ( $j = 0; $j < 12; $j++ ) { - if ( $ddate_m == $dmonths[$j] ) { - $ddate_m = $j+1; - } - } - - $time_zn = intval($date_arr[4]) * 36; - $ddate_U = gmmktime($ddate_H, $ddate_i, $ddate_s, $ddate_m, $ddate_d, $ddate_Y); - $ddate_U = $ddate_U - $time_zn; - $post_date = gmdate('Y-m-d H:i:s', $ddate_U + $time_difference); - $post_date_gmt = gmdate('Y-m-d H:i:s', $ddate_U); - } - } - } - - // Set $post_status based on $author_found and on author's publish_posts capability - if ( $author_found ) { - $user = new WP_User($post_author); - $post_status = ( $user->has_cap('publish_posts') ) ? 'publish' : 'pending'; - } else { - // Author not found in DB, set status to pending. Author already set to admin. - $post_status = 'pending'; - } - - $subject = trim($subject); - - if ( $content_type == 'multipart/alternative' ) { - $content = explode('--'.$boundary, $content); - $content = $content[2]; - // match case-insensitive content-transfer-encoding - if ( preg_match( '/Content-Transfer-Encoding: quoted-printable/i', $content, $delim) ) { - $content = explode($delim[0], $content); - $content = $content[1]; - } - $content = strip_tags($content, '" . sprintf(__('Author: %s'), esc_html($post_author)) . ' " . sprintf(__('Posted title: %s'), esc_html($post_title)) . ' ' . sprintf(__('Oops: %s'), esc_html($pop3->ERROR)) . ' ' . sprintf(__('Mission complete. Message %s deleted.'), $i) . '