* @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 $user User performing the action or null to use $wgUser * @param string|string[] $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 ) { global $wgUser; $user = $wgUser; } $action = $auto ? 'autopatrol' : 'patrol'; $entry = new ManualLogEntry( 'patrol', $action ); $entry->setTarget( $rc->getTitle() ); $entry->setParameters( self::buildParams( $rc, $auto ) ); $entry->setPerformer( $user ); $entry->setTags( $tags ); $logid = $entry->insert(); if ( !$auto ) { $entry->publish( $logid, 'udp' ); } return true; } /** * Prepare log parameters for a patrolled change * * @param RecentChange $change RecentChange to represent * @param bool $auto Whether the patrol event was automatic * @return array */ private static function buildParams( $change, $auto ) { return [ '4::curid' => $change->getAttribute( 'rc_this_oldid' ), '5::previd' => $change->getAttribute( 'rc_last_oldid' ), '6::auto' => (int)$auto ]; } }