deleteSelfExternals.php 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. <?php
  2. /**
  3. * Delete self-references to $wgServer from the externallinks table.
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation; either version 2 of the License, or
  8. * (at your option) any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License along
  16. * with this program; if not, write to the Free Software Foundation, Inc.,
  17. * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  18. * http://www.gnu.org/copyleft/gpl.html
  19. *
  20. * @file
  21. * @ingroup Maintenance
  22. */
  23. require_once __DIR__ . '/Maintenance.php';
  24. /**
  25. * Maintenance script that deletes self-references to $wgServer
  26. * from the externallinks table.
  27. *
  28. * @ingroup Maintenance
  29. */
  30. class DeleteSelfExternals extends Maintenance {
  31. public function __construct() {
  32. parent::__construct();
  33. $this->addDescription( 'Delete self-references to $wgServer from externallinks' );
  34. $this->setBatchSize( 1000 );
  35. }
  36. public function execute() {
  37. global $wgServer;
  38. $this->output( "Deleting self externals from $wgServer\n" );
  39. $db = $this->getDB( DB_MASTER );
  40. while ( 1 ) {
  41. $this->commitTransaction( $db, __METHOD__ );
  42. $q = $db->limitResult( "DELETE /* deleteSelfExternals */ FROM externallinks WHERE el_to"
  43. . $db->buildLike( $wgServer . '/', $db->anyString() ), $this->getBatchSize() );
  44. $this->output( "Deleting a batch\n" );
  45. $db->query( $q );
  46. if ( !$db->affectedRows() ) {
  47. return;
  48. }
  49. }
  50. }
  51. }
  52. $maintClass = DeleteSelfExternals::class;
  53. require_once RUN_MAINTENANCE_IF_MAIN;