2007-07-31 17:53:37 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* Created on July 30, 2007
|
|
|
|
|
*
|
|
|
|
|
* API for MediaWiki 1.8+
|
|
|
|
|
*
|
|
|
|
|
* Copyright (C) 2007 Yuri Astrakhan <Firstname><Lastname>@gmail.com
|
|
|
|
|
*
|
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
|
* (at your option) any later version.
|
|
|
|
|
*
|
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
|
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
|
* http://www.gnu.org/copyleft/gpl.html
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
if (!defined('MEDIAWIKI')) {
|
|
|
|
|
// Eclipse helper - will be ignored in production
|
|
|
|
|
require_once ('ApiQueryBase.php');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Query module to get information about the currently logged-in user
|
|
|
|
|
*
|
|
|
|
|
* @addtogroup API
|
|
|
|
|
*/
|
|
|
|
|
class ApiQueryUserInfo extends ApiQueryBase {
|
|
|
|
|
|
|
|
|
|
public function __construct($query, $moduleName) {
|
|
|
|
|
parent :: __construct($query, $moduleName, 'ui');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function execute() {
|
|
|
|
|
$params = $this->extractRequestParams();
|
|
|
|
|
$result = $this->getResult();
|
2008-01-24 17:59:07 +00:00
|
|
|
$r = array();
|
|
|
|
|
|
|
|
|
|
if (!is_null($params['prop'])) {
|
|
|
|
|
$this->prop = array_flip($params['prop']);
|
|
|
|
|
} else {
|
|
|
|
|
$this->prop = array();
|
|
|
|
|
}
|
2008-01-27 20:28:36 +00:00
|
|
|
$r = $this->getCurrentUserInfo();
|
2008-01-24 17:59:07 +00:00
|
|
|
$result->addValue("query", $this->getModuleName(), $r);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected function getCurrentUserInfo() {
|
|
|
|
|
global $wgUser;
|
|
|
|
|
$result = $this->getResult();
|
2007-07-31 17:53:37 +00:00
|
|
|
$vals = array();
|
2008-01-24 17:59:07 +00:00
|
|
|
$vals['id'] = $wgUser->getId();
|
2007-07-31 17:53:37 +00:00
|
|
|
$vals['name'] = $wgUser->getName();
|
|
|
|
|
|
2008-02-01 13:43:01 +00:00
|
|
|
if($wgUser->isAnon())
|
|
|
|
|
$vals['anon'] = '';
|
2008-01-24 17:59:07 +00:00
|
|
|
if (isset($this->prop['blockinfo'])) {
|
|
|
|
|
if ($wgUser->isBlocked()) {
|
|
|
|
|
$vals['blockedby'] = User::whoIs($wgUser->blockedBy());
|
|
|
|
|
$vals['blockreason'] = $wgUser->blockedFor();
|
2008-01-23 20:13:58 +00:00
|
|
|
}
|
2008-01-24 17:59:07 +00:00
|
|
|
}
|
|
|
|
|
if (isset($this->prop['hasmsg']) && $wgUser->getNewtalk()) {
|
|
|
|
|
$vals['messages'] = '';
|
2007-07-31 17:53:37 +00:00
|
|
|
}
|
2008-01-24 17:59:07 +00:00
|
|
|
if (isset($this->prop['groups'])) {
|
|
|
|
|
$vals['groups'] = $wgUser->getGroups();
|
|
|
|
|
$result->setIndexedTagName($vals['groups'], 'g'); // even if empty
|
|
|
|
|
}
|
|
|
|
|
if (isset($this->prop['rights'])) {
|
|
|
|
|
$vals['rights'] = $wgUser->getRights();
|
|
|
|
|
$result->setIndexedTagName($vals['rights'], 'r'); // even if empty
|
|
|
|
|
}
|
|
|
|
|
if (isset($this->prop['options'])) {
|
|
|
|
|
$vals['options'] = (is_null($wgUser->mOptions) ? User::getDefaultOptions() : $wgUser->mOptions);
|
|
|
|
|
}
|
|
|
|
|
if (isset($this->prop['editcount'])) {
|
|
|
|
|
$vals['editcount'] = $wgUser->getEditCount();
|
|
|
|
|
}
|
|
|
|
|
return $vals;
|
2007-07-31 17:53:37 +00:00
|
|
|
}
|
|
|
|
|
|
2008-01-28 19:05:26 +00:00
|
|
|
public function getAllowedParams() {
|
2007-07-31 17:53:37 +00:00
|
|
|
return array (
|
|
|
|
|
'prop' => array (
|
|
|
|
|
ApiBase :: PARAM_DFLT => NULL,
|
|
|
|
|
ApiBase :: PARAM_ISMULTI => true,
|
|
|
|
|
ApiBase :: PARAM_TYPE => array (
|
|
|
|
|
'blockinfo',
|
|
|
|
|
'hasmsg',
|
|
|
|
|
'groups',
|
|
|
|
|
'rights',
|
2008-01-23 20:13:58 +00:00
|
|
|
'options',
|
|
|
|
|
'editcount'
|
2008-01-24 17:59:07 +00:00
|
|
|
)
|
|
|
|
|
)
|
2007-07-31 17:53:37 +00:00
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
2008-01-28 19:05:26 +00:00
|
|
|
public function getParamDescription() {
|
2007-07-31 17:53:37 +00:00
|
|
|
return array (
|
|
|
|
|
'prop' => array(
|
|
|
|
|
'What pieces of information to include',
|
2008-02-01 13:43:01 +00:00
|
|
|
' blockinfo - tags if the current user is blocked, by whom, and for what reason',
|
|
|
|
|
' hasmsg - adds a tag "message" if the current user has pending messages',
|
|
|
|
|
' groups - lists all the groups the current user belongs to',
|
|
|
|
|
' rights - lists of all rights the current user has',
|
|
|
|
|
' options - lists all preferences the current user has set',
|
|
|
|
|
' editcount - adds the current user\'s edit count'
|
|
|
|
|
)
|
2007-07-31 17:53:37 +00:00
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
2008-01-28 19:05:26 +00:00
|
|
|
public function getDescription() {
|
2008-01-27 20:28:36 +00:00
|
|
|
return 'Get information about the current user';
|
2007-07-31 17:53:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected function getExamples() {
|
|
|
|
|
return array (
|
|
|
|
|
'api.php?action=query&meta=userinfo',
|
|
|
|
|
'api.php?action=query&meta=userinfo&uiprop=blockinfo|groups|rights|hasmsg',
|
|
|
|
|
'api.php?action=query&meta=userinfo&uioption=rememberpassword',
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function getVersion() {
|
2007-12-06 18:33:18 +00:00
|
|
|
return __CLASS__ . ': $Id$';
|
2007-07-31 17:53:37 +00:00
|
|
|
}
|
|
|
|
|
}
|