X-Git-Url: https://scripts.mit.edu/gitweb/autoinstallsdev/mediawiki.git/blobdiff_plain/8989532d3de45b196373107c7a812a68ac0ff2d9..d75ce11339b35963b5f8c3d53190819c1c025716:/maintenance/deleteSelfExternals.php diff --git a/maintenance/deleteSelfExternals.php b/maintenance/deleteSelfExternals.php new file mode 100644 index 00000000..1ab2839e --- /dev/null +++ b/maintenance/deleteSelfExternals.php @@ -0,0 +1,54 @@ +mDescription = 'Delete self-references to $wgServer from externallinks'; + $this->mBatchSize = 1000; + } + + public function execute() { + global $wgServer; + $this->output( "Deleting self externals from $wgServer\n" ); + $db = wfGetDB(DB_MASTER); + while (1) { + wfWaitForSlaves( 2 ); + $db->commit(); + $q = $db->limitResult( "DELETE /* deleteSelfExternals */ FROM externallinks WHERE el_to" + . $db->buildLike( $wgServer . '/', $db->anyString() ), $this->mBatchSize ); + $this->output( "Deleting a batch\n" ); + $db->query($q); + if (!$db->affectedRows()) exit(0); + } + } +} + +$maintClass = "DeleteSelfExternals"; +require_once( DO_MAINTENANCE );