93 parent::__construct( $query, $moduleName,
'us' );
102 $db = $this->
getDB();
106 if ( $params[
'prop'] !==
null ) {
107 $this->prop = array_fill_keys( $params[
'prop'],
true );
111 $useNames = $params[
'users'] !==
null;
113 $users = (array)$params[
'users'];
114 $userids = (array)$params[
'userids'];
116 $goodNames = $done = [];
119 foreach ( $users as $u ) {
120 $n = $this->userNameUtils->getCanonical( $u );
121 if ( $n ===
false || $n ===
'' ) {
122 $vals = [
'name' => $u,
'invalid' =>
true ];
123 $fit = $result->addValue( [
'query', $this->
getModuleName() ],
127 implode(
'|', array_diff( $users, $done ) ) );
138 $parameters = &$goodNames;
140 $parameters = &$userids;
145 if ( count( $parameters ) ) {
147 $this->
addTables( $userQuery[
'tables'] );
148 $this->
addFields( $userQuery[
'fields'] );
163 if ( isset( $this->prop[
'groups'] ) || isset( $this->prop[
'rights'] ) ) {
174 $this->
addJoinConds( [
'user_groups' => [
'JOIN',
'ug_user=user_id' ] ] );
176 $this->
addFields( $this->userGroupManager->getQueryInfo()[
'fields'] );
177 $this->
addWhere(
'ug_expiry IS NULL OR ug_expiry >= ' .
178 $db->addQuotes( $db->timestamp() ) );
179 $userGroupsRes = $this->
select( __METHOD__ );
181 foreach ( $userGroupsRes as $row ) {
182 $userGroups[$row->user_name][] = $row;
186 foreach (
$res as $row ) {
189 if ( !isset( $userGroups ) ) {
190 $user = $this->userFactory->newFromRow( $row );
192 if ( !isset( $userGroups[$row->user_name] ) || !is_array( $userGroups[$row->user_name] ) ) {
193 $userGroups[$row->user_name] = [];
195 $user = $this->userFactory->newFromRow( $row, [
'user_groups' => $userGroups[$row->user_name] ] );
198 $key = $user->getName();
200 $key = $user->getId();
202 $data[$key][
'userid'] = $user->getId();
203 $data[$key][
'name'] = $user->getName();
205 if ( isset( $this->prop[
'editcount'] ) ) {
206 $data[$key][
'editcount'] = $user->getEditCount();
209 if ( isset( $this->prop[
'registration'] ) ) {
210 $data[$key][
'registration'] =
wfTimestampOrNull( TS_ISO_8601, $user->getRegistration() );
213 if ( isset( $this->prop[
'groups'] ) ) {
214 $data[$key][
'groups'] = $this->userGroupManager->getUserEffectiveGroups( $user );
217 if ( isset( $this->prop[
'groupmemberships'] ) ) {
218 $data[$key][
'groupmemberships'] = array_map(
static function ( $ugm ) {
220 'group' => $ugm->getGroup(),
221 'expiry' => ApiResult::formatExpiry( $ugm->getExpiry() ),
223 }, $this->userGroupManager->getUserGroupMemberships( $user ) );
226 if ( isset( $this->prop[
'implicitgroups'] ) ) {
227 $data[$key][
'implicitgroups'] = $this->userGroupManager->getUserImplicitGroups( $user );
230 if ( isset( $this->prop[
'rights'] ) ) {
232 ->getUserPermissions( $user );
234 if ( $row->ipb_deleted ) {
235 $data[$key][
'hidden'] =
true;
237 if ( isset( $this->prop[
'blockinfo'] ) && $row->ipb_by_text !==
null ) {
238 $data[$key] += $this->getBlockDetails( DatabaseBlock::newFromRow( $row ) );
241 if ( isset( $this->prop[
'emailable'] ) ) {
242 $data[$key][
'emailable'] = $user->canReceiveEmail();
245 if ( isset( $this->prop[
'gender'] ) ) {
246 $gender = $this->userOptionsLookup->getOption( $user,
'gender' );
247 if ( strval( $gender ) ===
'' ) {
250 $data[$key][
'gender'] = $gender;
253 if ( isset( $this->prop[
'centralids'] ) ) {
255 $this->
getConfig(), $user, $params[
'attachedwiki']
263 foreach ( $parameters as $u ) {
264 if ( !isset( $data[$u] ) ) {
266 $data[$u] = [
'name' => $u ];
270 $iwUser = $urPage->fetchUser( $u );
273 $data[$u][
'interwiki'] =
true;
275 $data[$u][
'missing'] =
true;
276 if ( isset( $this->prop[
'cancreate'] ) ) {
277 $status = $this->authManager->canCreateAccount( $u );
278 $data[$u][
'cancreate'] = $status->isGood();
279 if ( !$status->isGood() ) {
280 $data[$u][
'cancreateerror'] = $this->
getErrorFormatter()->arrayFromStatus( $status );
285 $data[$u] = [
'userid' => $u,
'missing' =>
true ];
289 if ( isset( $this->prop[
'groups'] ) && isset( $data[$u][
'groups'] ) ) {
290 ApiResult::setArrayType( $data[$u][
'groups'],
'array' );
291 ApiResult::setIndexedTagName( $data[$u][
'groups'],
'g' );
293 if ( isset( $this->prop[
'groupmemberships'] ) && isset( $data[$u][
'groupmemberships'] ) ) {
294 ApiResult::setArrayType( $data[$u][
'groupmemberships'],
'array' );
295 ApiResult::setIndexedTagName( $data[$u][
'groupmemberships'],
'groupmembership' );
297 if ( isset( $this->prop[
'implicitgroups'] ) && isset( $data[$u][
'implicitgroups'] ) ) {
298 ApiResult::setArrayType( $data[$u][
'implicitgroups'],
'array' );
299 ApiResult::setIndexedTagName( $data[$u][
'implicitgroups'],
'g' );
301 if ( isset( $this->prop[
'rights'] ) && isset( $data[$u][
'rights'] ) ) {
302 ApiResult::setArrayType( $data[$u][
'rights'],
'array' );
303 ApiResult::setIndexedTagName( $data[$u][
'rights'],
'r' );
307 $fit = $result->addValue( [
'query', $this->
getModuleName() ],
null, $data[$u] );
311 implode(
'|', array_diff( $users, $done ) ) );
314 implode(
'|', array_diff( $userids, $done ) ) );
320 $result->addIndexedTagName( [
'query', $this->
getModuleName() ],
'user' );
324 if ( array_diff( (array)$params[
'prop'], static::$publicProps ) ) {
325 return 'anon-public-user-private';
352 'attachedwiki' =>
null,
365 'action=query&list=users&ususers=Example&usprop=groups|editcount|gender'
366 =>
'apihelp-query+users-example-simple',
371 return 'https://www.mediawiki.org/wiki/Special:MyLanguage/API:Users';
addBlockInfoToQuery( $showBlockInfo)
Filters hidden users (where the user doesn't have the right to view them) Also adds relevant block in...
wfTimestampOrNull( $outputtype=TS_UNIX, $ts=null)
Return a formatted timestamp, or null if input is null.
getPermissionManager()
Obtain a PermissionManager instance that subclasses may use in their authorization checks.
const PARAM_HELP_MSG_PER_VALUE
((string|array|Message)[]) When PARAM_TYPE is an array, this is an array mapping those values to $msg...
requireMaxOneParameter( $params,... $required)
Die if more than one of a certain set of parameters is set and not false.
getResult()
Get the result object.
extractRequestParams( $options=[])
Using getAllowedParams(), this function makes an array of the values provided by the user,...
getModuleName()
Get the name of the module being executed by this instance.
This is a base class for all Query modules.
setContinueEnumParameter( $paramName, $paramValue)
Set a query-continue value.
resetQueryParams()
Blank the internal arrays with query parameters.
addFields( $value)
Add a set of fields to select to the internal array.
addTables( $tables, $alias=null)
Add a set of tables to the internal array.
getDB()
Get the Query database connection (read-only)
select( $method, $extraQuery=[], array &$hookData=null)
Execute a SELECT query based on the values in the internal arrays.
addJoinConds( $join_conds)
Add a set of JOIN conditions to the internal array.
addWhereFld( $field, $value)
Equivalent to addWhere( [ $field => $value ] )
addWhere( $value)
Add a set of WHERE clauses to the internal array.
static getCentralUserInfo(Config $config, UserIdentity $user, $attachedWiki=UserIdentity::LOCAL)
Get central user info.
Query module to get information about a list of users.
execute()
Evaluates the parameters, performs the requested query, and sets up the result.
static array $publicProps
Properties whose contents does not depend on who is looking at them.
getHelpUrls()
Return links to more detailed help pages about the module.
UserGroupManager $userGroupManager
__construct(ApiQuery $query, $moduleName, UserNameUtils $userNameUtils, UserFactory $userFactory, UserGroupManager $userGroupManager, UserOptionsLookup $userOptionsLookup, AuthManager $authManager)
getAllowedParams()
Returns an array of allowed parameters (parameter name) => (default value) or (parameter name) => (ar...
UserOptionsLookup $userOptionsLookup
getExamplesMessages()
Returns usage examples for this module.
getCacheMode( $params)
Get the cache mode for the data generated by this module.
UserNameUtils $userNameUtils
This is the main query class.
getContext()
Get the base IContextSource object.
setContext( $context)
Sets the context this SpecialPage is executed in.
Cut-down copy of User interface for local-interwiki-database user rights manipulation.
static getQueryInfo()
Return the tables, fields, and join conditions to be selected to create a new user object.
Special page to allow managing user group membership.
trait ApiQueryBlockInfoTrait