getText( 'username' ); $this->requestedUser = ''; if ( $un != '' ) { $username = Title::makeTitleSafe( NS_USER, $un ); if( !is_null( $username ) ) { $this->requestedUser = $username->getText(); } } parent::__construct(); } function getIndexField() { return 'rc_user_text'; } function getQueryInfo() { $dbr = wfGetDB( DB_SLAVE ); $conds = array('rc_user > 0'); // Users - no anons $conds[] = 'ipb_deleted IS NULL'; // don't show hidden names $conds[] = 'rc_log_type IS NULL OR rc_log_type != "newusers"'; $useIndex = $dbr->useIndexClause( 'rc_user_text' ); if( $this->requestedUser != '' ) { $conds[] = 'rc_user_text >= ' . $dbr->addQuotes( $this->requestedUser ); } list( $recentchanges, $ipblocks, $user ) = $dbr->tableNamesN( 'recentchanges', 'ipblocks', 'user' ); $query = array( 'tables' => "$recentchanges $useIndex INNER JOIN $user ON rc_user_text=user_name LEFT JOIN $ipblocks ON user_id=ipb_user AND ipb_auto=0 AND ipb_deleted=1 ", 'fields' => array( 'rc_user_text AS user_name', // inheritance 'rc_user_text', // for Pager 'user_id', 'COUNT(*) AS recentedits', 'MAX(ipb_user) AS blocked' ), 'options' => array( 'GROUP BY' => 'rc_user_text' ), 'conds' => $conds ); return $query; } function formatRow( $row ) { $userName = $row->rc_user_text; $userPage = Title::makeTitle( NS_USER, $userName ); $name = $this->getSkin()->makeLinkObj( $userPage, htmlspecialchars( $userPage->getText() ) ); $list = array(); foreach( self::getGroups( $row->user_id ) as $group ) $list[] = self::buildGroupLink( $group ); $groups = implode( ', ', $list ); $item = wfSpecialList( $name, $groups ); $count = wfMsgExt( 'activeusers-count', array( 'parsemag' ), $row->recentedits, $userName ); $blocked = $row->blocked ? ' ' . wfMsgExt( 'listusers-blocked', array( 'parsemag' ), $userName ) : ''; return "
' . wfMsgHtml( 'activeusers-noresult' ) . '
'; } $wgOut->addHTML( $s ); } }