addInternal( $event ); } /** * @param Event $event */ private function addInternal( Event $event ) { $this->events[] = $event; } private function filterEventsWithTitleDbLag() { return array_filter( $this->events, static function ( Event $event ) { if ( !$event->getTitle() && $event->getTitle( true ) ) { // It is very likely this event was found // unrenderable because of replica lag. // Do not moderate it at this time. LoggerFactory::getInstance( 'Echo' )->debug( 'EchoDeferredMarkAsDeletedUpdate: Event {eventId} was found unrenderable' . ' but its associated title exists on primary database. Skipping.', [ 'eventId' => $event->getId(), 'title' => $event->getTitle()->getPrefixedText(), ] ); return false; } return true; } ); } /** * Marks all queued notifications as read. * Satisfies DeferrableUpdate interface */ public function doUpdate() { $events = $this->filterEventsWithTitleDbLag(); $eventIds = array_map( static function ( Event $event ) { return $event->getId(); }, $events ); ModerationController::moderate( $eventIds, true ); $this->events = []; } }