<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head><meta http-equiv="content-type" content="text/html; charset=utf-8" /><style type="text/css"><!--
#msg dl { border: 1px #006 solid; background: #369; padding: 6px; color: #fff; }
#msg dt { float: left; width: 6em; font-weight: bold; }
#msg dt:after { content:':';}
#msg dl, #msg dt, #msg ul, #msg li, #header, #footer { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt; }
#msg dl a { font-weight: bold}
#msg dl a:link { color:#fc3; }
#msg dl a:active { color:#ff0; }
#msg dl a:visited { color:#cc6; }
h3 { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt; font-weight: bold; }
#msg pre { overflow: auto; background: #ffc; border: 1px #fc0 solid; padding: 6px; }
#msg ul, pre { overflow: auto; }
#header, #footer { color: #fff; background: #636; border: 1px #300 solid; padding: 6px; }
#patch { width: 100%; }
#patch h4 {font-family: verdana,arial,helvetica,sans-serif;font-size:10pt;padding:8px;background:#369;color:#fff;margin:0;}
#patch .propset h4, #patch .binary h4 {margin:0;}
#patch pre {padding:0;line-height:1.2em;margin:0;}
#patch .diff {width:100%;background:#eee;padding: 0 0 10px 0;overflow:auto;}
#patch .propset .diff, #patch .binary .diff {padding:10px 0;}
#patch span {display:block;padding:0 10px;}
#patch .modfile, #patch .addfile, #patch .delfile, #patch .propset, #patch .binary, #patch .copfile {border:1px solid #ccc;margin:10px 0;}
#patch ins {background:#dfd;text-decoration:none;display:block;padding:0 10px;}
#patch del {background:#fdd;text-decoration:none;display:block;padding:0 10px;}
#patch .lines, .info {color:#888;background:#fff;}
--></style>
<title>[17052] trunk/wp-includes/comment.php: Fix Pings/
Trackback comment table filter.</title>
</head>
<body>
<div id="msg">
<dl>
<dt>Revision</dt> <dd><a href="http://trac.wordpress.org/changeset/17052">17052</a></dd>
<dt>Author</dt> <dd>dd32</dd>
<dt>Date</dt> <dd>2010-12-19 04:55:46 +0000 (Sun, 19 Dec 2010)</dd>
</dl>
<h3>Log Message</h3>
<pre>Fix Pings/Trackback comment table filter. Props greuben. Fixes <a href="http://trac.wordpress.org/ticket/15885">#15885</a></pre>
<h3>Modified Paths</h3>
<ul>
<li><a href="#trunkwpincludescommentphp">trunk/wp-includes/comment.php</a></li>
</ul>
</div>
<div id="patch">
<h3>Diff</h3>
<a id="trunkwpincludescommentphp"></a>
<div class="modfile"><h4>Modified: trunk/wp-includes/comment.php (17051 => 17052)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/wp-includes/comment.php        2010-12-19 04:38:04 UTC (rev 17051)
+++ trunk/wp-includes/comment.php        2010-12-19 04:55:46 UTC (rev 17052)
</span><span class="lines">@@ -305,10 +305,13 @@
</span><span class="cx">                         $where .= $wpdb->prepare( ' AND comment_author_email = %s', $author_email );
</span><span class="cx">                 if ( '' !== $karma )
</span><span class="cx">                         $where .= $wpdb->prepare( ' AND comment_karma = %d', $karma );
</span><del>-                if ( 'comment' == $type )
</del><ins>+                if ( 'comment' == $type ) {
</ins><span class="cx">                         $where .= " AND comment_type = ''";
</span><del>-                elseif ( ! empty( $type ) )
</del><ins>+                } elseif( 'pings' == $type ) {
+                        $where .= ' AND comment_type IN ("pingback", "trackback")';
+                } elseif ( ! empty( $type ) ) {
</ins><span class="cx">                         $where .= $wpdb->prepare( ' AND comment_type = %s', $type );
</span><ins>+                }
</ins><span class="cx">                 if ( '' !== $parent )
</span><span class="cx">                         $where .= $wpdb->prepare( ' AND comment_parent = %d', $parent );
</span><span class="cx">                 if ( '' !== $user_id )
</span><span class="lines">@@ -1759,7 +1762,7 @@
</span><span class="cx">         $post_links = array();
</span><span class="cx">
</span><span class="cx">         $pung = get_pung($post_ID);
</span><del>-
</del><ins>+var_Dump(compact('pung'));
</ins><span class="cx">         // Variables
</span><span class="cx">         $ltrs = '\w';
</span><span class="cx">         $gunk = '/#~:.?+=&%@!\-';
</span><span class="lines">@@ -1782,7 +1785,7 @@
</span><span class="cx">         // We don't wanna ping first and second types, even if they have a valid <link/>
</span><span class="cx">
</span><span class="cx">         foreach ( (array) $post_links_temp[0] as $link_test ) :
</span><del>-                if ( !in_array($link_test, $pung) && (url_to_postid($link_test) != $post_ID) // If we haven't pung it already and it isn't a link to itself
</del><ins>+                if ( !in_array($link_test, $pung) && !in_array($link_test, $post_links) && (url_to_postid($link_test) != $post_ID) // If we haven't pung it already and it isn't a link to itself
</ins><span class="cx">                                 && !is_local_attachment($link_test) ) : // Also, let's never ping local attachments.
</span><span class="cx">                         if ( $test = @parse_url($link_test) ) {
</span><span class="cx">                                 if ( isset($test['query']) )
</span><span class="lines">@@ -1792,11 +1795,12 @@
</span><span class="cx">                         }
</span><span class="cx">                 endif;
</span><span class="cx">         endforeach;
</span><del>-
</del><ins>+var_dump(compact('post_links', 'post_links_temp'));
</ins><span class="cx">         do_action_ref_array('pre_ping', array(&$post_links, &$pung));
</span><span class="cx">
</span><span class="cx">         foreach ( (array) $post_links as $pagelinkedto ) {
</span><span class="cx">                 $pingback_server_url = discover_pingback_server_uri( $pagelinkedto );
</span><ins>+                var_dump(compact('pagelinkedto', 'pingback_server_url'));
</ins><span class="cx">
</span><span class="cx">                 if ( $pingback_server_url ) {
</span><span class="cx">                         @ set_time_limit( 60 );
</span><span class="lines">@@ -1805,13 +1809,15 @@
</span><span class="cx">
</span><span class="cx">                         // using a timeout of 3 seconds should be enough to cover slow servers
</span><span class="cx">                         $client = new WP_HTTP_IXR_Client($pingback_server_url);
</span><del>-                        $client->timeout = 3;
</del><ins>+                        $client->timeout = 5;
</ins><span class="cx">                         $client->useragent = apply_filters( 'pingback_useragent', $client->useragent . ' -- WordPress/' . $wp_version, $client->useragent, $pingback_server_url, $pagelinkedto, $pagelinkedfrom);
</span><span class="cx">                         // when set to true, this outputs debug messages by itself
</span><del>-                        $client->debug = false;
</del><ins>+                        $client->debug = true;
</ins><span class="cx">
</span><span class="cx">                         if ( $client->query('pingback.ping', $pagelinkedfrom, $pagelinkedto) || ( isset($client->error->code) && 48 == $client->error->code ) ) // Already registered
</span><span class="cx">                                 add_ping( $post_ID, $pagelinkedto );
</span><ins>+                        var_Dump($client);
+                        echo '<hr />';
</ins><span class="cx">                 }
</span><span class="cx">         }
</span><span class="cx"> }
</span></span></pre>
</div>
</div>
</body>
</html>