3 * Implements Special:Listusers
5 * Copyright © 2004 Brion Vibber, lcrocker, Tim Starling,
6 * Domas Mituzas, Antoine Musso, Jens Frank, Zhengzhu,
7 * 2006 Rob Church <robchur@gmail.com>
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License along
20 * with this program; if not, write to the Free Software Foundation, Inc.,
21 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
22 * http://www.gnu.org/copyleft/gpl.html
25 * @ingroup SpecialPage
29 * @ingroup SpecialPage
31 class SpecialListUsers
extends IncludableSpecialPage
{
33 public function __construct() {
34 parent
::__construct( 'Listusers' );
38 * @param string|null $par (optional) A group to list users from
40 public function execute( $par ) {
42 $this->outputHeader();
44 $up = new UsersPager( $this->getContext(), $par, $this->including() );
46 # getBody() first to check, if empty
47 $usersbody = $up->getBody();
50 if ( !$this->including() ) {
51 $s = $up->getPageHeader();
55 $s .= $up->getNavigationBar();
56 $s .= Html
::rawElement( 'ul', [], $usersbody );
57 $s .= $up->getNavigationBar();
59 $s .= $this->msg( 'listusers-noresult' )->parseAsBlock();
62 $this->getOutput()->addHTML( $s );
66 * Return an array of subpages that this special page will accept.
68 * @return string[] subpages
70 public function getSubpagesForPrefixSearch() {
71 return User
::getAllGroups();
74 protected function getGroupName() {