68 public function run() {
73 if ( isset( $this->params[
'table'] ) && !isset( $this->params[
'pages'] ) ) {
74 $this->params[
'recursive'] =
true;
78 if ( !empty( $this->params[
'recursive'] ) ) {
82 $extraParams[
'causeAction'] = $this->params[
'causeAction'];
83 $extraParams[
'causeAgent'] = $this->params[
'causeAgent'];
86 $jobs = BacklinkJobUtils::partitionBacklinkJob(
91 [
'params' => $extraParams ]
95 } elseif ( isset( $this->params[
'pages'] ) ) {
101 $t->getArticleID() => [ $t->getNamespace(), $t->getDBkey() ]
113 $pageIds = array_keys( $pages );
118 $rootTsUnix =
wfTimestampOrNull( TS::UNIX, $this->params[
'rootJobTimestamp'] ??
null );
129 $casTsUnix = $rootTsUnix ?? $newTouchedUnix;
132 $config = $services->getMainConfig();
134 $dbProvider = $services->getConnectionProvider();
135 $dbw = $dbProvider->getPrimaryDatabase();
136 $ticket = $dbProvider->getEmptyTransactionTicket( __METHOD__ );
140 foreach ( $batches as $batch ) {
141 $dbw->newUpdateQueryBuilder()
143 ->set( [
'page_touched' => $dbw->timestamp( $newTouchedUnix ) ] )
144 ->where( [
'page_id' => $batch ] )
145 ->andWhere( $dbw->expr(
'page_touched',
'<', $dbw->timestamp( $casTsUnix ) ) )
146 ->caller( __METHOD__ )->execute();
147 if ( count( $batches ) > 1 ) {
148 $dbProvider->commitAndWaitForReplication( __METHOD__, $ticket );
152 $queryBuilder = $dbw->newSelectQueryBuilder()
153 ->select( [
'page_namespace',
'page_title' ] )
155 ->where( [
'page_id' => $pageIds,
'page_touched' => $dbw->timestamp( $newTouchedUnix ) ] );
157 $queryBuilder->field(
'page_lang' );
159 $titleArray = $services->getTitleFactory()->newTitleArrayFromResult(
160 $queryBuilder->caller( __METHOD__ )->fetchResultSet()
164 $htmlCache = $services->getHtmlCacheUpdater();
165 $htmlCache->purgeTitleUrls(
167 $htmlCache::PURGE_NAIVE | $htmlCache::PURGE_URLS_LINKSUPDATE_ONLY,
168 [ $htmlCache::UNLESS_CACHE_MTIME_AFTER => $casTsUnix + self::NORMAL_MAX_LAG ]