addDescription( 'Remove cache entries for removed ResourceLoader modules from the database' ); $this->setBatchSize( 500 ); } public function execute() { $this->output( "Cleaning up module_deps table...\n" ); $dbw = $this->getPrimaryDB(); $rl = $this->getServiceContainer()->getResourceLoader(); $moduleNames = $rl->getModuleNames(); $res = $dbw->newSelectQueryBuilder() ->select( [ 'md_module', 'md_skin' ] ) ->from( 'module_deps' ) ->where( $moduleNames ? $dbw->expr( 'md_module', '!=', $moduleNames ) : [] ) ->caller( __METHOD__ ) ->fetchResultSet(); $rows = iterator_to_array( $res, false ); $modDeps = $dbw->tableName( 'module_deps' ); $i = 1; foreach ( array_chunk( $rows, $this->getBatchSize() ) as $chunk ) { // WHERE ( mod=A AND skin=A ) OR ( mod=A AND skin=B) .. $conds = array_map( static function ( stdClass $row ) use ( $dbw ) { return $dbw->makeList( (array)$row, IDatabase::LIST_AND ); }, $chunk ); $conds = $dbw->makeList( $conds, IDatabase::LIST_OR ); $this->beginTransaction( $dbw, __METHOD__ ); $dbw->query( "DELETE FROM $modDeps WHERE $conds", __METHOD__ ); $numRows = $dbw->affectedRows(); $this->output( "Batch $i: $numRows rows\n" ); $this->commitTransaction( $dbw, __METHOD__ ); $i++; } $this->output( "Done\n" ); } } // @codeCoverageIgnoreStart $maintClass = CleanupRemovedModules::class; require_once RUN_MAINTENANCE_IF_MAIN; // @codeCoverageIgnoreEnd