Merge "RefreshLinksJob: Restore LinksUpdate::setTriggeringUser() call"
authorjenkins-bot <jenkins-bot@gerrit.wikimedia.org>
Tue, 22 Dec 2015 00:38:55 +0000 (00:38 +0000)
committerGerrit Code Review <gerrit@wikimedia.org>
Tue, 22 Dec 2015 00:38:55 +0000 (00:38 +0000)
includes/jobqueue/jobs/RefreshLinksJob.php

index 183c1ee..c8a9892 100644 (file)
@@ -222,6 +222,24 @@ class RefreshLinksJob extends Job {
                        $parserOutput
                );
 
+               foreach ( $updates as $key => $update ) {
+                       // FIXME: This code probably shouldn't be here?
+                       // Needed by things like Echo notifications which need
+                       // to know which user caused the links update
+                       if ( $update instanceof LinksUpdate ) {
+                               if ( !empty( $this->params['triggeringUser'] ) ) {
+                                       $userInfo = $this->params['triggeringUser'];
+                                       if ( $userInfo['userId'] ) {
+                                               $user = User::newFromId( $userInfo['userId'] );
+                                       } else {
+                                               // Anonymous, use the username
+                                               $user = User::newFromName( $userInfo['userName'], false );
+                                       }
+                                       $update->setTriggeringUser( $user );
+                               }
+                       }
+               }
+
                $latestNow = $page->lockAndGetLatest();
                if ( !$latestNow || $revision->getId() != $latestNow ) {
                        // Do not clobber over newer updates with older ones. If all jobs where FIFO and