Re-establishing validation feature (the beginnings)
[lhc/web/wiklou.git] / includes / SquidUpdate.php
index 462de3f..294fca4 100644 (file)
@@ -1,40 +1,78 @@
 <?php
-# See deferred.doc
+/**
+ * See deferred.doc
+ * @package MediaWiki
+ */
 
+/**
+ *
+ * @package MediaWiki
+ */
 class SquidUpdate {
-       var $urlArr;
+       var $urlArr, $mMaxTitles;
 
-       function SquidUpdate( $urlArr = Array() ) {
+       function SquidUpdate( $urlArr = Array(), $maxTitles = false ) {
+               global $wgMaxSquidPurgeTitles;
+               if ( $maxTitles === false ) {
+                       $this->mMaxTitles = $wgMaxSquidPurgeTitles;
+               } else {
+                       $this->mMaxTitles = $maxTitles;
+               }
+               if ( count( $urlArr ) > $this->mMaxTitles ) {
+                       $urlArr = array_slice( $urlArr, 0, $this->mMaxTitles );
+               }
                $this->urlArr = $urlArr;
        }
 
        /* static */ function newFromLinksTo( &$title ) {
+               $fname = 'SquidUpdate::newFromLinksTo';
+               wfProfileIn( $fname );
+
                # Get a list of URLs linking to this page
                $id = $title->getArticleID();
-               $sql = "SELECT cur_namespace,cur_title FROM links,cur WHERE l_to={$id} and l_from=cur_id" ;
-               $res = wfQuery ( $sql, DB_READ ) ;
+
+               $dbr =& wfGetDB( DB_SLAVE );
+               $links = $dbr->tableName( 'links' );
+               $page = $dbr->tableName( 'page' );
+
+               $sql = "SELECT page_namespace,page_title FROM $links,$page WHERE l_to={$id} and l_from=page_id" ;
+               $res = $dbr->query( $sql, $fname ) ;
                $blurlArr = $title->getSquidURLs();
-               while ( $BL = wfFetchObject ( $res ) )
-               {
-                       $tobj = Title::makeTitle( $BL->cur_namespace, $BL->cur_title ) ; 
-                       $blurlArr[] = $tobj->getInternalURL();
+               if ( $dbr->numRows( $res ) <= $this->mMaxTitles ) {
+                       while ( $BL = $dbr->fetchObject ( $res ) )
+                       {
+                               $tobj = Title::makeTitle( $BL->page_namespace, $BL->page_title ) ; 
+                               $blurlArr[] = $tobj->getInternalURL();
+                       }
                }
-               wfFreeResult ( $res ) ;
+               $dbr->freeResult ( $res ) ;
+
+               wfProfileOut( $fname );
                return new SquidUpdate( $blurlArr );
        }
 
        /* static */ function newFromBrokenLinksTo( &$title ) {
+               $fname = 'SquidUpdate::newFromBrokenLinksTo';
+               wfProfileIn( $fname );
+
                # Get a list of URLs linking to this (currently non-existent) page
-               $encTitle = $title->getPrefixedDBkey();
-               $sql = "SELECT cur_namespace,cur_title FROM brokenlinks,cur WHERE bl_to={$encTitle} AND bl_from=cur_id";
-               $res = wfQuery( $sql, DB_READ );
+               $dbr =& wfGetDB( DB_SLAVE );
+               $brokenlinks = $dbr->tableName( 'brokenlinks' );
+               $page = $dbr->tableName( 'page' );
+               $encTitle = $dbr->addQuotes( $title->getPrefixedDBkey() );
+
+               $sql = "SELECT page_namespace,page_title FROM $brokenlinks,$cur WHERE bl_to={$encTitle} AND bl_from=page_id";
+               $res = $dbr->query( $sql, $fname );
                $blurlArr = array();
-               while ( $BL = wfFetchObject( $res ) )
-               {
-                       $tobj = Title::makeTitle( $BL->cur_namespace, $BL->cur_title );
-                       $blurlArr[] = $tobj->getInternalURL();
+               if ( $dbr->numRows( $res ) <= $this->mMaxTitles ) {
+                       while ( $BL = $dbr->fetchObject( $res ) )
+                       {
+                               $tobj = Title::makeTitle( $BL->page_namespace, $BL->page_title );
+                               $blurlArr[] = $tobj->getInternalURL();
+                       }
                }
-               wfFreeResult( $res );
+               $dbr->freeResult( $res );
+               wfProfileOut( $fname );
                return new SquidUpdate( $blurlArr );
        }
 
@@ -55,11 +93,14 @@ class SquidUpdate {
        /* static */ function purge( $urlArr ) {
                global  $wgSquidServers;
 
-               if ( $wgSquidServers == "echo" ) {
-                       echo implode("<br>\n", $urlArr);
+               if ( $wgSquidServers == 'echo' ) {
+                       echo implode("<br />\n", $urlArr);
                        return;
                }
 
+               $fname = 'SquidUpdate::purge';
+               wfProfileIn( $fname );
+               
                $maxsocketspersquid = 8; //  socket cap per Squid
                $urlspersocket = 400; // 400 seems to be a good tradeoff, opening a socket takes a while
                $firsturl = $urlArr[0];
@@ -85,14 +126,20 @@ class SquidUpdate {
                                        /* first socket for this server, do the tests */
                                        @list($server, $port) = explode(':', $wgSquidServers[$ss]);
                                        if(!isset($port)) $port = 80;
+                                       #$this->debug("Opening socket to $server:$port");
                                        $socket = @fsockopen($server, $port, $error, $errstr, 3);
+                                       #$this->debug("\n");
                                        if (!$socket) {
                                                $failed = true;
                                                $totalsockets -= $sockspersq;
                                        } else {
-                                               @fputs($socket,"PURGE " . $firsturl . " HTTP/1.0\r\n".
-                                               "Connection: Keep-Alive\r\n\r\n");
+                                               $msg = 'PURGE ' . $firsturl . " HTTP/1.0\r\n".
+                                               "Connection: Keep-Alive\r\n\r\n";
+                                               #$this->debug($msg);
+                                               @fputs($socket,$msg);
+                                               #$this->debug("...");
                                                $res = @fread($socket,512);
+                                               #$this->debug("\n");
                                                /* Squid only returns http headers with 200 or 404 status, 
                                                if there's more returned something's wrong */
                                                if (strlen($res) > 250) {
@@ -129,12 +176,15 @@ class SquidUpdate {
                                                }
                                        }
                                        $urindex = $r + $urlspersocket * ($s - $sockspersq * floor($s / $sockspersq));
-                                       @fputs($sockets[$s],"PURGE " . $urlArr[$urindex] . " HTTP/1.0\r\n".
-                                       "Connection: Keep-Alive\r\n\r\n");
+                                       $msg = 'PURGE ' . $urlArr[$urindex] . " HTTP/1.0\r\n".
+                                       "Connection: Keep-Alive\r\n\r\n";
+                                       #$this->debug($msg);
+                                       @fputs($sockets[$s],$msg);
+                                       #$this->debug("\n");
                                }
                        }
                }
-
+               #$this->debug("Reading response...");
                foreach ($sockets as $socket) {
                        $res = '';
                        $esc = 0;
@@ -146,6 +196,15 @@ class SquidUpdate {
 
                        @fclose($socket);
                }
+               #$this->debug("\n");
+               wfProfileOut( $fname );
+       }
+
+       function debug( $text ) {
+               global $wgDebugSquid;
+               if ( $wgDebugSquid ) {
+                       wfDebug( $text );
+               }
        }
 }
 ?>