From: Antoine Musso Date: Sun, 6 Mar 2011 21:01:54 +0000 (+0000) Subject: Script to purge all pages of a given namespace X-Git-Tag: 1.31.0-rc.0~31592 X-Git-Url: http://git.cyclocoop.org/%24self?a=commitdiff_plain;h=bb651b00630fce5e60138df409e9ec530236cf21;p=lhc%2Fweb%2Fwiklou.git Script to purge all pages of a given namespace --- diff --git a/maintenance/purgeNamespace.php b/maintenance/purgeNamespace.php new file mode 100644 index 0000000000..0759ca0f3c --- /dev/null +++ b/maintenance/purgeNamespace.php @@ -0,0 +1,96 @@ +mDescription = "Purge squids pages for a given namespace"; + $this->addOption( "namespace", "Namespace number", true, true ); + $this->setBatchSize( 100 ); + parent::__construct(); + } + + public function execute() { + $dbr = wfGetDB( DB_SLAVE ); + $ns = $dbr->addQuotes( $this->getOption( 'namespace') ); + + $result = $dbr->select( + array( 'page' ), + array( 'page_namespace', 'page_title' ), + array( "page_namespace = $ns" ), + __METHOD__, + array( 'ORDER BY' => 'page_id' ) + ); + + $start = 0; + $end = $dbr->numRows( $result ); + $this->output( "Will purge $end pages from namespace $ns\n" ); + + # Do remaining chunk + $end += $this->mBatchSize - 1; + $blockStart = $start; + $blockEnd = $start + $this->mBatchSize - 1; + + while( $blockEnd <= $end ) { + # Select pages we will purge: + $result = $dbr->select( + array( 'page' ), + array( 'page_namespace', 'page_title' ), + array( "page_namespace = $ns" ), + __METHOD__, + array( # conditions + 'ORDER BY' => 'page_id', + 'LIMIT' => $this->mBatchSize, + 'OFFSET' => $blockStart, + ) + ); + + # Initialize/reset URLs to be purged + $urls = array(); + foreach( $result as $row ) { + $title = Title::makeTitle( $row->page_namespace, $row->page_title ); + $url = $title->getFullUrl(); + $urls[] = $url; + } + + $this->sendPurgeRequest( $urls ); + + $blockStart += $this->mBatchSize; + $blockEnd += $this->mBatchSize; + } + + $this->output( "Done!\n" ); + } + + private function sendPurgeRequest( $urls ) { + $this->output( "Purging " . count( $urls ). " urls\n" ); + $u = new SquidUpdate( $urls ); + $u->doUpdate(); + } +} + +$maintClass = "PurgeNamespace"; +require_once( RUN_MAINTENANCE_IF_MAIN ); +