2003-04-01 09:12:34 -05:00
|
|
|
<?php
|
2003-06-12 18:42:48 -04:00
|
|
|
require_once('wp-config.php');
|
|
|
|
require_once($abspath.$b2inc.'/b2template.functions.php');
|
2003-06-21 18:14:55 -04:00
|
|
|
require_once($abspath.$b2inc.'/b2vars.php');
|
|
|
|
require_once($abspath.$b2inc.'/b2functions.php');
|
2003-04-01 09:12:34 -05:00
|
|
|
|
|
|
|
function add_magic_quotes($array) {
|
|
|
|
foreach ($array as $k => $v) {
|
|
|
|
if (is_array($v)) {
|
|
|
|
$array[$k] = add_magic_quotes($v);
|
|
|
|
} else {
|
|
|
|
$array[$k] = addslashes($v);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $array;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!get_magic_quotes_gpc()) {
|
|
|
|
$HTTP_GET_VARS = add_magic_quotes($HTTP_GET_VARS);
|
|
|
|
$HTTP_POST_VARS = add_magic_quotes($HTTP_POST_VARS);
|
|
|
|
$HTTP_COOKIE_VARS = add_magic_quotes($HTTP_COOKIE_VARS);
|
|
|
|
}
|
|
|
|
|
2003-10-03 18:31:47 -04:00
|
|
|
$author = trim(strip_tags($HTTP_POST_VARS['author']));
|
|
|
|
|
|
|
|
$email = trim(strip_tags($HTTP_POST_VARS['email']));
|
|
|
|
if (strlen($email) < 6)
|
|
|
|
$email = '';
|
|
|
|
|
|
|
|
$url = trim(strip_tags($HTTP_POST_VARS['url']));
|
|
|
|
$url = ((!stristr($url, '://')) && ($url != '')) ? 'http://'.$url : $url;
|
|
|
|
if (strlen($url) < 7)
|
|
|
|
$url = '';
|
|
|
|
|
2003-08-31 21:26:20 -04:00
|
|
|
$comment = trim($HTTP_POST_VARS['comment']);
|
2003-04-01 09:12:34 -05:00
|
|
|
$original_comment = $comment;
|
2003-10-03 18:31:47 -04:00
|
|
|
$comment_post_ID = intval($HTTP_POST_VARS['comment_post_ID']);
|
|
|
|
$user_ip = $HTTP_SERVER_VARS['REMOTE_ADDR'];
|
|
|
|
$user_domain = gethostbyaddr($user_ip);
|
2003-04-01 09:12:34 -05:00
|
|
|
|
2003-06-04 14:17:48 -04:00
|
|
|
$commentstatus = $wpdb->get_var("SELECT comment_status FROM $tableposts WHERE ID = $comment_post_ID");
|
|
|
|
|
|
|
|
if ('closed' == $commentstatus)
|
|
|
|
die('Sorry, comments are closed for this item.');
|
|
|
|
|
2003-06-08 11:45:37 -04:00
|
|
|
if ($require_name_email && ($email == '' || $email == '@' || $author == '' || $author == 'name')) { //original fix by Dodo, and then Drinyth
|
|
|
|
echo 'Error: please fill the required fields (name, email).';
|
2003-04-01 09:12:34 -05:00
|
|
|
exit;
|
|
|
|
}
|
2003-06-08 11:45:37 -04:00
|
|
|
if ($comment == 'comment' || $comment == '') {
|
2003-04-01 09:12:34 -05:00
|
|
|
echo "Error: please type a comment";
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
2003-08-31 21:26:20 -04:00
|
|
|
$time_difference = get_settings('time_difference');
|
|
|
|
$now = date('Y-m-d H:i:s',(time() + ($time_difference * 3600)));
|
2003-04-01 09:12:34 -05:00
|
|
|
|
2003-10-03 18:31:47 -04:00
|
|
|
$comment = strip_tags($comment, $comment_allowed_tags);
|
2003-04-01 09:12:34 -05:00
|
|
|
$comment = balanceTags($comment, 1);
|
|
|
|
$comment = convert_chars($comment);
|
|
|
|
$comment = format_to_post($comment);
|
|
|
|
|
|
|
|
$comment_author = $author;
|
|
|
|
$comment_author_email = $email;
|
|
|
|
$comment_author_url = $url;
|
|
|
|
|
|
|
|
$author = addslashes($author);
|
|
|
|
$email = addslashes($email);
|
|
|
|
$url = addslashes($url);
|
|
|
|
|
|
|
|
/* flood-protection */
|
2003-05-29 10:04:30 -04:00
|
|
|
$lasttime = $wpdb->get_var("SELECT comment_date FROM $tablecomments WHERE comment_author_IP = '$user_ip' ORDER BY comment_date DESC LIMIT 1");
|
2003-10-03 18:31:47 -04:00
|
|
|
$ok = true;
|
2003-05-29 10:04:30 -04:00
|
|
|
if (!empty($lasttime)) {
|
|
|
|
$time_lastcomment= mysql2date('U', $lasttime);
|
|
|
|
$time_newcomment= mysql2date('U', "$now");
|
2003-08-07 16:30:30 -04:00
|
|
|
if (($time_newcomment - $time_lastcomment) < 10)
|
2003-10-03 18:31:47 -04:00
|
|
|
$ok = false;
|
2003-04-01 09:12:34 -05:00
|
|
|
}
|
|
|
|
/* end flood-protection */
|
|
|
|
|
2003-06-04 14:17:48 -04:00
|
|
|
|
|
|
|
|
2003-08-31 21:26:20 -04:00
|
|
|
if ($ok) { // if there was no comment from this IP in the last 10 seconds
|
2003-04-01 09:12:34 -05:00
|
|
|
|
2003-10-03 18:31:47 -04:00
|
|
|
$wpdb->query("INSERT INTO $tablecomments VALUES ('0', '$comment_post_ID', '$author', '$email', '$url', '$user_ip', '$now', '$comment', '0')");
|
2003-04-01 09:12:34 -05:00
|
|
|
|
2003-08-31 21:26:20 -04:00
|
|
|
if ($comments_notify) {
|
2003-04-01 09:12:34 -05:00
|
|
|
$postdata = get_postdata($comment_post_ID);
|
2003-04-07 02:12:32 -04:00
|
|
|
$authordata = get_userdata($postdata['Author_ID']);
|
2003-04-01 09:12:34 -05:00
|
|
|
|
2003-08-31 21:26:20 -04:00
|
|
|
if('' != $authordata->user_email) {
|
|
|
|
$notify_message = "New comment on your post #$comment_post_ID \"".stripslashes($postdata['Title'])."\"\r\n\r\n";
|
|
|
|
$notify_message .= "Author : $comment_author (IP: $user_ip , $user_domain)\r\n";
|
|
|
|
$notify_message .= "E-mail : $comment_author_email\r\n";
|
|
|
|
$notify_message .= "URL : $comment_author_url\r\n";
|
|
|
|
$notify_message .= "Whois : http://ws.arin.net/cgi-bin/whois.pl?queryinput=$user_ip\r\n";
|
|
|
|
$notify_message .= "Comment:\r\n".stripslashes($original_comment)."\r\n\r\n";
|
|
|
|
$notify_message .= "You can see all comments on this post here: \r\n";
|
|
|
|
$notify_message .= $siteurl.'/'.$blogfilename.$querystring_start.'p'.$querystring_equal.$comment_post_ID.$querystring_separator.'c'.$querystring_equal.'1#comments';
|
|
|
|
|
|
|
|
$subject = '[' . stripslashes($blogname) . '] Comment: "' .stripslashes($postdata['Title']).'"';
|
|
|
|
|
|
|
|
if ('' != $comment_author_email) {
|
|
|
|
$from = "From: \"$comment_author\" <$comment_author_email>\r\n";
|
|
|
|
} else {
|
2003-09-03 13:45:45 -04:00
|
|
|
$from = 'From: "' . stripslashes($comment_author) . "\" <$authordata->user_email>\r\n";
|
2003-08-31 21:26:20 -04:00
|
|
|
}
|
|
|
|
$from .= "X-Mailer: WordPress $b2_version with PHP/" . phpversion();
|
|
|
|
|
|
|
|
@mail($authordata->user_email, $subject, $notify_message, $from);
|
|
|
|
}
|
2003-04-01 09:12:34 -05:00
|
|
|
}
|
|
|
|
|
2003-08-31 21:26:20 -04:00
|
|
|
if ($email == '')
|
2003-04-07 02:55:21 -04:00
|
|
|
$email = ' '; // this to make sure a cookie is set for 'no email'
|
2003-08-31 21:26:20 -04:00
|
|
|
|
|
|
|
if ($url == '')
|
2003-04-07 02:55:21 -04:00
|
|
|
$url = ' '; // this to make sure a cookie is set for 'no url'
|
2003-08-31 21:26:20 -04:00
|
|
|
|
2003-05-29 10:04:30 -04:00
|
|
|
setcookie('comment_author', $author, time()+30000000);
|
|
|
|
setcookie('comment_author_email', $email, time()+30000000);
|
|
|
|
setcookie('comment_author_url', $url, time()+30000000);
|
2003-04-07 02:55:21 -04:00
|
|
|
|
|
|
|
header('Expires: Mon, 26 Jul 1997 05:00:00 GMT');
|
2003-05-29 10:04:30 -04:00
|
|
|
header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT');
|
2003-04-07 02:55:21 -04:00
|
|
|
header('Cache-Control: no-cache, must-revalidate');
|
|
|
|
header('Pragma: no-cache');
|
2003-04-01 09:12:34 -05:00
|
|
|
$location = (!empty($HTTP_POST_VARS['redirect_to'])) ? $HTTP_POST_VARS['redirect_to'] : $HTTP_SERVER_VARS["HTTP_REFERER"];
|
2003-06-15 18:44:54 -04:00
|
|
|
if ($is_IIS) {
|
|
|
|
header("Refresh: 0;url=$location");
|
|
|
|
} else {
|
|
|
|
header("Location: $location");
|
|
|
|
}
|
2003-04-01 09:12:34 -05:00
|
|
|
} else {
|
2003-08-31 21:26:20 -04:00
|
|
|
die('Sorry, you can only post a new comment once every 10 seconds. Slow down cowboy.');
|
2003-04-01 09:12:34 -05:00
|
|
|
}
|
|
|
|
|
2003-04-07 02:55:21 -04:00
|
|
|
?>
|