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() {
|
|
|
|
|
|
|
|
|
|
global $wgUser;
|
|
|
|
|
|
|
|
|
|
$params = $this->extractRequestParams();
|
|
|
|
|
$result = $this->getResult();
|
|
|
|
|
|
|
|
|
|
$vals = array();
|
|
|
|
|
$vals['name'] = $wgUser->getName();
|
|
|
|
|
|
|
|
|
|
if( $wgUser->isAnon() ) $vals['anon'] = '';
|
|
|
|
|
|
|
|
|
|
if (!is_null($params['prop'])) {
|
|
|
|
|
$prop = array_flip($params['prop']);
|
|
|
|
|
if (isset($prop['blockinfo'])) {
|
|
|
|
|
if ($wgUser->isBlocked()) {
|
2007-08-01 20:11:29 +00:00
|
|
|
$vals['blockedby'] = User::whoIs($wgUser->blockedBy());
|
2007-07-31 17:53:37 +00:00
|
|
|
$vals['blockreason'] = $wgUser->blockedFor();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (isset($prop['hasmsg']) && $wgUser->getNewtalk()) {
|
|
|
|
|
$vals['messages'] = '';
|
|
|
|
|
}
|
|
|
|
|
if (isset($prop['groups'])) {
|
|
|
|
|
$vals['groups'] = $wgUser->getGroups();
|
|
|
|
|
$result->setIndexedTagName($vals['groups'], 'g'); // even if empty
|
|
|
|
|
}
|
|
|
|
|
if (isset($prop['rights'])) {
|
|
|
|
|
$vals['rights'] = $wgUser->getRights();
|
|
|
|
|
$result->setIndexedTagName($vals['rights'], 'r'); // even if empty
|
|
|
|
|
}
|
2007-11-03 16:08:43 +00:00
|
|
|
if (isset($prop['options'])) {
|
|
|
|
|
$vals['options'] = (is_null($wgUser->mOptions) ? User::getDefaultOptions() : $wgUser->mOptions);
|
2007-07-31 17:53:37 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$result->addValue(null, $this->getModuleName(), $vals);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected function getAllowedParams() {
|
|
|
|
|
return array (
|
|
|
|
|
'prop' => array (
|
|
|
|
|
ApiBase :: PARAM_DFLT => NULL,
|
|
|
|
|
ApiBase :: PARAM_ISMULTI => true,
|
|
|
|
|
ApiBase :: PARAM_TYPE => array (
|
|
|
|
|
'blockinfo',
|
|
|
|
|
'hasmsg',
|
|
|
|
|
'groups',
|
|
|
|
|
'rights',
|
2007-11-03 16:08:43 +00:00
|
|
|
'options'
|
|
|
|
|
))
|
2007-07-31 17:53:37 +00:00
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected function getParamDescription() {
|
|
|
|
|
return array (
|
|
|
|
|
'prop' => array(
|
|
|
|
|
'What pieces of information to include',
|
|
|
|
|
' blockinfo - tags if the user is blocked, by whom, and for what reason',
|
|
|
|
|
' hasmsg - adds a tag "message" if user has pending messages',
|
|
|
|
|
' groups - lists all the groups the current user belongs to',
|
|
|
|
|
' rights - lists of all rights the current user has',
|
2007-11-03 16:08:43 +00:00
|
|
|
' options - lists all preferences the current user has set'
|
|
|
|
|
)
|
2007-07-31 17:53:37 +00:00
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected function getDescription() {
|
|
|
|
|
return 'Get information about the current user';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
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:22:15 +00:00
|
|
|
return __CLASS__ . ': $Id: ApiQueryUserInfo.php 27153 2007-11-03 16:08:43Z catrope $';
|
2007-07-31 17:53:37 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|