* @author Niklas Laxström */ /** * Class containing static functions for working with * logs of patrol events */ class PatrolLog { /** * Record a log event for a change being patrolled * * @param int|RecentChange $rc Change identifier or RecentChange object * @param bool $auto Was this patrol event automatic? * @param User|null $user User performing the action or null to use $wgUser * (null to use $wgUser is deprecated since 1.35) * @param string|string[]|null $tags Change tags to add to the patrol log entry * ($user should be able to add the specified tags before this is called) * * @return bool */ public static function record( $rc, $auto = false, User $user = null, $tags = null ) { // Do not log autopatrol actions: T184485 if ( $auto ) { return false; } if ( !$rc instanceof RecentChange ) { $rc = RecentChange::newFromId( $rc ); if ( !is_object( $rc ) ) { return false; } } if ( !$user ) { wfDeprecated( __METHOD__ . ' without passing a $user parameter', '1.35' ); global $wgUser; $user = $wgUser; } $entry = new ManualLogEntry( 'patrol', 'patrol' ); $entry->setTarget( $rc->getTitle() ); $entry->setParameters( self::buildParams( $rc ) ); $entry->setPerformer( $user ); $entry->addTags( $tags ); $logid = $entry->insert(); $entry->publish( $logid, 'udp' ); return true; } /** * Prepare log parameters for a patrolled change * * @param RecentChange $change RecentChange to represent * @return array */ private static function buildParams( $change ) { return [ '4::curid' => $change->getAttribute( 'rc_this_oldid' ), '5::previd' => $change->getAttribute( 'rc_last_oldid' ), '6::auto' => 0 ]; } }