Skip to content
Browse files

New mail functionality.

git-svn-id: http://svn.automattic.com/wordpress/trunk@1153 1a063a9b-81f0-0310-95a4-ce76da25c4cd
  • Loading branch information...
1 parent 595c041 commit a0ad8e4dc0859a3cc9e56d88f697d46fea21e776 saxmatt committed Apr 24, 2004
Showing with 54 additions and 191 deletions.
  1. +54 −191 wp-mail.php
View
245 wp-mail.php
@@ -3,45 +3,29 @@
require_once(ABSPATH.WPINC.'/class-pop3.php');
-
-timer_start();
-
-$output_debugging_info = 0; # =1 if you want to output debugging info
-
-if (get_settings('use_phoneemail')) {
- // if you're using phone email, the email will already be in your timezone
- $time_difference = 0;
-}
-
error_reporting(2037);
-
-
$pop3 = new POP3();
-if(!$pop3->connect(get_settings('mailserver_url'), get_settings('mailserver_port'))) {
+if (!$pop3->connect(get_settings('mailserver_url'), get_settings('mailserver_port'))) :
echo "Ooops $pop3->ERROR <br />\n";
exit;
-}
+endif;
-$Count = $pop3->login(get_settings('mailserver_login'), get_settings('mailserver_pass'));
-if((!$Count) || ($Count == -1)) {
- echo "<h1>Login Failed: $pop3->ERROR</h1>\n";
- $pop3->quit();
- exit;
-}
+$count = $pop3->login(get_settings('mailserver_login'), get_settings('mailserver_pass'));
+if (0 == $count) die(__('There doesn&#8217;t seem to be any new mail.'));
-// ONLY USE THIS IF YOUR PHP VERSION SUPPORTS IT!
-//register_shutdown_function($pop3->quit());
+for ($i=1; $i <= $count; $i++) :
-for ($iCount=1; $iCount<=$Count; $iCount++) {
+ $message = $pop3->get($i);
- $MsgOne = $pop3->get($iCount);
- if((!$MsgOne) || (gettype($MsgOne) != 'array')) {
- echo "oops, $pop3->ERROR<br />\n";
- $pop3->quit();
+ if(!$pop3->delete($i)) {
+ echo '<p>Oops '.$pop3->ERROR.'</p></div>';
+ $pop3->reset();
exit;
+ } else {
+ echo "<p>Mission complete, message <strong>$i</strong> deleted.</p>";
}
$content = '';
@@ -50,10 +34,9 @@
$bodysignal = 0;
$dmonths = array('Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun',
'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec');
- while ( list ( $lineNum,$line ) = each ($MsgOne) ) {
- if (strlen($line) < 3) {
- $bodysignal = 1;
- }
+ foreach ($message as $line) :
+ if (strlen($line) < 3) $bodysignal = 1;
+
if ($bodysignal) {
$content .= $line;
} else {
@@ -74,13 +57,6 @@
if (!preg_match('#\=\?(.+)\?Q\?(.+)\?\=#i', $subject)) {
$subject = wp_iso_descrambler($subject);
}
- if (get_settings('use_phoneemail')) {
- $subject = explode(get_settings('phoneemail_separator'), $subject);
- $subject = trim($subject[0]);
- }
- if (!ereg(get_settings('subjectprefix'), $subject)) {
- continue;
- }
}
if (preg_match('/Date: /', $line)) { // of the form '20 Mar 2002 20:32:37'
$ddate = trim($line);
@@ -109,183 +85,70 @@
$post_date_gmt = gmdate('Y-m-d H:i:s', $ddate_U);
}
}
- }
+ endforeach;
$ddate_today = time() + ($time_difference * 3600);
$ddate_difference_days = ($ddate_today - $ddate_U) / 86400;
- # starts buffering the output
- ob_start();
+ $subject = trim(str_replace(get_settings('subjectprefix'), '', $subject));
- if ($ddate_difference_days > 14) {
- echo 'Too old<br />';
- continue;
+ if ($content_type == 'multipart/alternative') {
+ $content = explode('--'.$boundary, $content);
+ $content = $content[2];
+ $content = explode('Content-Transfer-Encoding: quoted-printable', $content);
+ $content = strip_tags($content[1], '<img><p><br><i><b><u><em><strong><strike><font><span><div>');
}
+ $content = trim($content);
- if (preg_match('/'.get_settings('subjectprefix').'/', $subject)) {
+ echo "<p><b>Content-type:</b> $content_type, <b>boundary:</b> $boundary</p>\n";
+ echo "<p><b>Raw content:</b><br /><pre>".$content.'</pre></p>';
- $userpassstring = '';
+ $content = trim($content);
- echo '<div style="border: 1px dashed #999; padding: 10px; margin: 10px;">';
- echo "<p><b>$iCount</b></p><p><b>Subject: </b>$subject</p>\n";
+ $content = trim($content);
- $subject = trim(str_replace(get_settings('subjectprefix'), '', $subject));
+ $post_title = xmlrpc_getposttitle($content);
- if ($content_type == 'multipart/alternative') {
- $content = explode('--'.$boundary, $content);
- $content = $content[2];
- $content = explode('Content-Transfer-Encoding: quoted-printable', $content);
- $content = strip_tags($content[1], '<img><p><br><i><b><u><em><strong><strike><font><span><div>');
- }
- $content = trim($content);
-
- echo "<p><b>Content-type:</b> $content_type, <b>boundary:</b> $boundary</p>\n";
- echo "<p><b>Raw content:</b><br /><pre>".$content.'</pre></p>';
-
- $btpos = strpos($content, get_settings('bodyterminator'));
- if ($btpos) {
- $content = substr($content, 0, $btpos);
- }
- $content = trim($content);
-
- $blah = explode("\n", $content);
- $firstline = $blah[0];
- $secondline = $blah[1];
-
- if (get_settings('use_phoneemail')) {
- $btpos = strpos($firstline, get_settings('phoneemail_separator'));
- if ($btpos) {
- $userpassstring = trim(substr($firstline, 0, $btpos));
- $content = trim(substr($content, $btpos+strlen(get_settings('phoneemail_separator')), strlen($content)));
- $btpos = strpos($content, get_settings('phoneemail_separator'));
- if ($btpos) {
- $userpassstring = trim(substr($content, 0, $btpos));
- $content = trim(substr($content, $btpos+strlen(get_settings('phoneemail_separator')), strlen($content)));
- }
- }
- $contentfirstline = $blah[1];
- } else {
- $userpassstring = $firstline;
- $contentfirstline = '';
- }
+ if ($post_title == '') $post_title = $subject;
- $flat = 999.0;
- $flon = 999.0;
- $secondlineParts = explode(':',$secondline);
- if(strncmp($secondlineParts[0],"POS",3)==0) {
- echo "Found POS:<br>\n";
- //echo "Second parts is:".$secondlineParts[1];
- // the second line is the postion listing line
- $secLineParts = explode(',',$secondlineParts[1]);
- $flatStr = $secLineParts[0];
- $flonStr = $secLineParts[1];
- //echo "String are ".$flatStr.$flonStr;
- $flat = floatval($secLineParts[0]);
- $flon = floatval($secLineParts[1]);
- //echo "values are ".$flat." and ".$flon;
- // ok remove that position... we should not have it in the final output
- $content = str_replace($secondline,'',$content);
- }
-
- $blah = explode(':', $userpassstring);
- $user_login = $blah[0];
- $user_pass = md5($blah[1]);
-
- $content = $contentfirstline.str_replace($firstline, '', $content);
- $content = trim($content);
-
- echo "<p><b>Login:</b> $user_login, <b>Pass:</b> $user_pass</p>";
-
- $sql = "SELECT ID, user_level FROM $tableusers WHERE user_login='$user_login' AND user_pass='$user_pass' ORDER BY ID DESC LIMIT 1";
- $result = $wpdb->get_row($sql);
-
- if (!$result) {
- echo '<p><b>Wrong login or password.</b></p></div>';
- continue;
- }
+ if (empty($post_categories)) $post_categories[] = get_settings('default_category');
- $user_level = $result->user_level;
- $post_author = $result->ID;
+ $post_title = addslashes(trim($post_title));
+ $content = preg_replace("|\n([^\n])|", " $1", $content);
+ $content = addslashes(trim($content));
- if ($user_level > 0) {
- $post_title = xmlrpc_getposttitle($content);
- $post_categories[] = xmlrpc_getpostcategory($content);
+ $sql = "INSERT INTO $tableposts (post_author, post_date, post_date_gmt, post_content, post_title, post_modified, post_modified_gmt) VALUES (1, '$post_date', '$post_date_gmt', '$content', '$post_title', '$post_date', '$post_date_gmt')";
- if ($post_title == '') {
- $post_title = $subject;
- }
- if (empty($post_categories)) {
- $post_categories[] = get_settings('default_category');
- }
+ $result = $wpdb->query($sql);
+ $post_ID = $wpdb->insert_id;
- if (!$thisisforfunonly) {
- $post_title = addslashes(trim($post_title));
- $content = preg_replace("|\n([^\n])|", " $1", $content);
- $content = addslashes(trim($content));
- if($flat > 500) {
- $sql = "INSERT INTO $tableposts (post_author, post_date, post_date_gmt, post_content, post_title, post_modified, post_modified_gmt) VALUES ($post_author, '$post_date', '$post_date_gmt', '$content', '$post_title', '$post_date', '$post_date_gmt')";
- } else {
- $sql = "INSERT INTO $tableposts (post_author, post_date, post_date_gmt, post_content, post_title, post_modified, post_modified_gmt, post_lat, post_lon) VALUES ($post_author, '$post_date', '$post_date_gmt', '$content', '$post_title', '$post_date', '$post_date_gmt', $flat, $flon)";
- }
- $result = $wpdb->query($sql);
- $post_ID = $wpdb->insert_id;
-
- if (isset($sleep_after_edit) && $sleep_after_edit > 0) {
- sleep($sleep_after_edit);
- }
- $blog_ID = 1;
- if($flat < 500) {
- pingGeoUrl($post_ID);
- }
+ pingback($content, $post_ID);
- pingback($content, $post_ID);
- }
- echo "\n<p><b>Posted title:</b> $post_title<br />";
- echo "\n<b>Posted content:</b><br /><pre>".$content.'</pre></p>';
-
- if (!$post_categories) $post_categories[] = 1;
- foreach ($post_categories as $post_category) {
- $post_category = intval($post_category);
-
- // Double check it's not there already
- $exists = $wpdb->get_row("SELECT * FROM $tablepost2cat WHERE post_id = $post_ID AND category_id = $post_category");
-
- if (!$exists && $result) {
- $wpdb->query("
- INSERT INTO $tablepost2cat
- (post_id, category_id)
- VALUES
- ($post_ID, $post_category)
- ");
- }
- }
+ echo "\n<p><b>Posted title:</b> $post_title<br />";
+ echo "\n<b>Posted content:</b><br /><pre>".$content.'</pre></p>';
- if(!$pop3->delete($iCount)) {
- echo '<p>Oops '.$pop3->ERROR.'</p></div>';
- $pop3->reset();
- exit;
- } else {
- echo "<p>Mission complete, message <strong>$iCount</strong> deleted.</p>";
- }
+if (!$post_categories) $post_categories[] = 1;
+foreach ($post_categories as $post_category) :
+ $post_category = intval($post_category);
- } else {
- echo '<p><strong>Level 0 users can\'t post.</strong></p>';
- }
- echo '</div>';
- if ($output_debugging_info) {
- ob_end_flush();
- } else {
- ob_end_clean();
- }
+ // Double check it's not there already
+ $exists = $wpdb->get_row("SELECT * FROM $tablepost2cat WHERE post_id = $post_ID AND category_id = $post_category");
+
+ if (!$exists && $result) {
+ $wpdb->query("
+ INSERT INTO $tablepost2cat
+ (post_id, category_id)
+ VALUES
+ ($post_ID, $post_category)
+ ");
}
-}
+endforeach;
-$pop3->quit();
+endfor;
-timer_stop($output_debugging_info);
-exit;
+$pop3->quit();
?>

0 comments on commit a0ad8e4

Please sign in to comment.
Something went wrong with that request. Please try again.