/** * get User from Cache * @return object */ private static function getUserCache() { if (self::$userCache == null) { self::$userCache = new HashBagOStuff(['maxKeys' => self::CACHE_MAX]); } return self::$userCache; }
public function execute() { $params = $this->extractRequestParams(); if (!is_null($params['prop'])) { $this->prop = array_flip($params['prop']); } else { $this->prop = []; } $users = (array) $params['users']; $goodNames = $done = []; $result = $this->getResult(); // Canonicalize user names foreach ($users as $u) { $n = User::getCanonicalName($u); if ($n === false || $n === '') { $vals = ['name' => $u, 'invalid' => true]; $fit = $result->addValue(['query', $this->getModuleName()], null, $vals); if (!$fit) { $this->setContinueEnumParameter('users', implode('|', array_diff($users, $done))); $goodNames = []; break; } $done[] = $u; } else { $goodNames[] = $n; } } $result = $this->getResult(); if (count($goodNames)) { $this->addTables('user'); $this->addFields(User::selectFields()); $this->addWhereFld('user_name', $goodNames); $this->showHiddenUsersAddBlockInfo(isset($this->prop['blockinfo'])); $data = []; $res = $this->select(__METHOD__); $this->resetQueryParams(); // get user groups if needed if (isset($this->prop['groups']) || isset($this->prop['rights'])) { $userGroups = []; $this->addTables('user'); $this->addWhereFld('user_name', $goodNames); $this->addTables('user_groups'); $this->addJoinConds(['user_groups' => ['INNER JOIN', 'ug_user=user_id']]); $this->addFields(['user_name', 'ug_group']); $userGroupsRes = $this->select(__METHOD__); foreach ($userGroupsRes as $row) { $userGroups[$row->user_name][] = $row->ug_group; } } foreach ($res as $row) { // create user object and pass along $userGroups if set // that reduces the number of database queries needed in User dramatically if (!isset($userGroups)) { $user = User::newFromRow($row); } else { if (!isset($userGroups[$row->user_name]) || !is_array($userGroups[$row->user_name])) { $userGroups[$row->user_name] = []; } $user = User::newFromRow($row, ['user_groups' => $userGroups[$row->user_name]]); } $huijiUser = HuijiUser::newFromUser($user); $name = $user->getName(); $data[$name]['userid'] = $user->getId(); $data[$name]['name'] = $name; if (isset($this->prop['editcount'])) { $data[$name]['editcount'] = $user->getEditCount(); } if (isset($this->prop['registration'])) { $data[$name]['registration'] = wfTimestampOrNull(TS_ISO_8601, $user->getRegistration()); } if (isset($this->prop['groups'])) { $data[$name]['groups'] = $user->getEffectiveGroups(); } if (isset($this->prop['implicitgroups'])) { $data[$name]['implicitgroups'] = $user->getAutomaticGroups(); } if (isset($this->prop['rights'])) { $data[$name]['rights'] = $user->getRights(); } if ($row->ipb_deleted) { $data[$name]['hidden'] = true; } if (isset($this->prop['blockinfo']) && !is_null($row->ipb_by_text)) { $data[$name]['blockid'] = (int) $row->ipb_id; $data[$name]['blockedby'] = $row->ipb_by_text; $data[$name]['blockedbyid'] = (int) $row->ipb_by; $data[$name]['blockedtimestamp'] = wfTimestamp(TS_ISO_8601, $row->ipb_timestamp); $data[$name]['blockreason'] = $row->ipb_reason; $data[$name]['blockexpiry'] = $row->ipb_expiry; } if (isset($this->prop['emailable'])) { $data[$name]['emailable'] = $user->canReceiveEmail(); } if (isset($this->prop['gender'])) { $gender = $user->getOption('gender'); if (strval($gender) === '') { $gender = 'unknown'; } $data[$name]['gender'] = $gender; } if (isset($this->prop['centralids'])) { $data[$name] += ApiQueryUserInfo::getCentralUserInfo($this->getConfig(), $user, $params['attachedwiki']); } if (isset($this->prop['designation'])) { $data[$name]['designation'] = $huijiUser->getDesignation(false, true); } if (isset($this->prop['avatar'])) { $data[$name]['avatar'] = array("l" => $huijiUser->getAvatar('l')->getAvatarUrlPath(), "ml" => $huijiUser->getAvatar('ml')->getAvatarUrlPath(), "m" => $huijiUser->getAvatar('m')->getAvatarUrlPath(), "s" => $huijiUser->getAvatar('s')->getAvatarUrlPath()); } if (isset($this->prop['status'])) { $us = new UserStatus($user); $data[$name]['status'] = $us->getStatus(); } if (isset($this->prop['birthday'])) { $us = new UserStatus($user); $data[$name]['birthday'] = $us->getBirthday(); } if (isset($this->prop['city'])) { $us = new UserStatus($user); $data[$name]['city'] = $us->getCity(); } if (isset($this->prop['province'])) { $us = new UserStatus($user); $data[$name]['province'] = $us->getProvince(); } if (isset($this->prop['followingcount'])) { $data[$name]['followingcount'] = $huijiUser->getFollowingUsersCount(); } if (isset($this->prop['followercount'])) { $data[$name]['followercount'] = $huijiUser->getFollowerCount(); } if (isset($this->prop['followingsitescount'])) { $data[$name]['followingsitescount'] = $huijiUser->getFollowingSitesCount(); } if (isset($this->prop['stats'])) { $data[$name]['stats'] = $huijiUser->getStats(); } if (isset($this->prop['level'])) { $data[$name]['level'] = $huijiUser->getLevel()->getLevelNumber(); } if (isset($this->prop['followingsites'])) { $vals['followingsites'] = $huijiUser->getFollowingSites(true); } if (isset($this->prop['context'])) { if ($this->getUser()->isLoggedIn()) { $data[$name]['context']['followedbyme'] = $huijiUser->isFollowedBy($this->getUser()) ? "true" : "false"; $me = HuijiUser::newFromUser($this->getUser()); $iAmFollowing = $me->getFollowingUsers(); $heIsFollowing = $huijiUser->getFollowingUsers(); $bothfollowing = []; if ($heIsFollowing != null) { foreach ($heIsFollowing as $someUser) { //Php is awesome... if (array_search($someUser['user_name'], array_column($iAmFollowing, 'user_name'))) { $bothfollowing[] = $someUser['user_name']; } } } $data[$name]['context']['bothfollowing'] = $bothfollowing; $data[$name]['context']['alsofollowing'] = UserStatus::getFollowingFollowsUser($huijiUser->getName(), $me->getName()); $data[$name]['context']['followingsites'] = $huijiUser->getFollowingSites(true, $this->getUser()); } else { $data[$name]['context'] = false; } } if (!is_null($params['token'])) { $tokenFunctions = $this->getTokenFunctions(); foreach ($params['token'] as $t) { $val = call_user_func($tokenFunctions[$t], $user); if ($val === false) { $this->setWarning("Action '{$t}' is not allowed for the current user"); } else { $data[$name][$t . 'token'] = $val; } } } } } $context = $this->getContext(); // Second pass: add result data to $retval foreach ($goodNames as $u) { if (!isset($data[$u])) { $data[$u] = ['name' => $u]; $urPage = new UserrightsPage(); $urPage->setContext($context); $iwUser = $urPage->fetchUser($u); if ($iwUser instanceof UserRightsProxy) { $data[$u]['interwiki'] = true; if (!is_null($params['token'])) { $tokenFunctions = $this->getTokenFunctions(); foreach ($params['token'] as $t) { $val = call_user_func($tokenFunctions[$t], $iwUser); if ($val === false) { $this->setWarning("Action '{$t}' is not allowed for the current user"); } else { $data[$u][$t . 'token'] = $val; } } } } else { $data[$u]['missing'] = true; if (isset($this->prop['cancreate']) && !$this->getConfig()->get('DisableAuthManager')) { $status = MediaWiki\Auth\AuthManager::singleton()->canCreateAccount($u); $data[$u]['cancreate'] = $status->isGood(); if (!$status->isGood()) { $data[$u]['cancreateerror'] = $this->getErrorFormatter()->arrayFromStatus($status); } } } } else { if (isset($this->prop['groups']) && isset($data[$u]['groups'])) { ApiResult::setArrayType($data[$u]['groups'], 'array'); ApiResult::setIndexedTagName($data[$u]['groups'], 'g'); } if (isset($this->prop['implicitgroups']) && isset($data[$u]['implicitgroups'])) { ApiResult::setArrayType($data[$u]['implicitgroups'], 'array'); ApiResult::setIndexedTagName($data[$u]['implicitgroups'], 'g'); } if (isset($this->prop['rights']) && isset($data[$u]['rights'])) { ApiResult::setArrayType($data[$u]['rights'], 'array'); ApiResult::setIndexedTagName($data[$u]['rights'], 'r'); } } $fit = $result->addValue(['query', $this->getModuleName()], null, $data[$u]); if (!$fit) { $this->setContinueEnumParameter('users', implode('|', array_diff($users, $done))); break; } $done[] = $u; } $result->addIndexedTagName(['query', $this->getModuleName()], 'user'); }
/** * Query user info based on filters. * * */ protected function getCurrentUserInfo() { $user = $this->getUser(); $huijiUser = HuijiUser::newFromUser($user); $vals = []; $vals['id'] = intval($user->getId()); $vals['name'] = $user->getName(); if ($user->isAnon()) { $vals['anon'] = true; } if (isset($this->prop['blockinfo']) && $user->isBlocked()) { $vals = array_merge($vals, self::getBlockInfo($user->getBlock())); } if (isset($this->prop['hasmsg'])) { $vals['messages'] = $user->getNewtalk(); } if (isset($this->prop['groups'])) { $vals['groups'] = $user->getEffectiveGroups(); ApiResult::setArrayType($vals['groups'], 'array'); // even if empty ApiResult::setIndexedTagName($vals['groups'], 'g'); // even if empty } if (isset($this->prop['implicitgroups'])) { $vals['implicitgroups'] = $user->getAutomaticGroups(); ApiResult::setArrayType($vals['implicitgroups'], 'array'); // even if empty ApiResult::setIndexedTagName($vals['implicitgroups'], 'g'); // even if empty } if (isset($this->prop['rights'])) { // User::getRights() may return duplicate values, strip them $vals['rights'] = array_values(array_unique($user->getRights())); ApiResult::setArrayType($vals['rights'], 'array'); // even if empty ApiResult::setIndexedTagName($vals['rights'], 'r'); // even if empty } if (isset($this->prop['changeablegroups'])) { $vals['changeablegroups'] = $user->changeableGroups(); ApiResult::setIndexedTagName($vals['changeablegroups']['add'], 'g'); ApiResult::setIndexedTagName($vals['changeablegroups']['remove'], 'g'); ApiResult::setIndexedTagName($vals['changeablegroups']['add-self'], 'g'); ApiResult::setIndexedTagName($vals['changeablegroups']['remove-self'], 'g'); } if (isset($this->prop['options'])) { $vals['options'] = $user->getOptions(); $vals['options'][ApiResult::META_BC_BOOLS] = array_keys($vals['options']); } if (isset($this->prop['preferencestoken'])) { $p = $this->getModulePrefix(); $this->setWarning("{$p}prop=preferencestoken has been deprecated. Please use action=query&meta=tokens instead."); } if (isset($this->prop['preferencestoken']) && !$this->lacksSameOriginSecurity() && $user->isAllowed('editmyoptions')) { $vals['preferencestoken'] = $user->getEditToken('', $this->getMain()->getRequest()); } if (isset($this->prop['editcount'])) { // use intval to prevent null if a non-logged-in user calls // api.php?format=jsonfm&action=query&meta=userinfo&uiprop=editcount $vals['editcount'] = intval($user->getEditCount()); } if (isset($this->prop['ratelimits'])) { $vals['ratelimits'] = $this->getRateLimits(); } if (isset($this->prop['realname']) && !in_array('realname', $this->getConfig()->get('HiddenPrefs'))) { $vals['realname'] = $user->getRealName(); } if ($user->isAllowed('viewmyprivateinfo')) { if (isset($this->prop['email'])) { $vals['email'] = $user->getEmail(); $auth = $user->getEmailAuthenticationTimestamp(); if (!is_null($auth)) { $vals['emailauthenticated'] = wfTimestamp(TS_ISO_8601, $auth); } } } if (isset($this->prop['registrationdate'])) { $regDate = $user->getRegistration(); if ($regDate !== false) { $vals['registrationdate'] = wfTimestamp(TS_ISO_8601, $regDate); } } if (isset($this->prop['acceptlang'])) { $langs = $this->getRequest()->getAcceptLang(); $acceptLang = []; foreach ($langs as $lang => $val) { $r = ['q' => $val]; ApiResult::setContentValue($r, 'code', $lang); $acceptLang[] = $r; } ApiResult::setIndexedTagName($acceptLang, 'lang'); $vals['acceptlang'] = $acceptLang; } if (isset($this->prop['unreadcount'])) { $store = MediaWikiServices::getInstance()->getWatchedItemStore(); $unreadNotifications = $store->countUnreadNotifications($user, self::WL_UNREAD_LIMIT); if ($unreadNotifications === true) { $vals['unreadcount'] = self::WL_UNREAD_LIMIT . '+'; } else { $vals['unreadcount'] = $unreadNotifications; } } if (isset($this->prop['centralids'])) { $vals += self::getCentralUserInfo($this->getConfig(), $this->getUser(), $this->params['attachedwiki']); } if (isset($this->prop['designation'])) { $vals['designation'] = $huijiUser->getDesignation(false, true); } if (isset($this->prop['avatar'])) { $vals['avatar'] = array("l" => $huijiUser->getAvatar('l')->getAvatarUrlPath(), "ml" => $huijiUser->getAvatar('ml')->getAvatarUrlPath(), "m" => $huijiUser->getAvatar('m')->getAvatarUrlPath(), "s" => $huijiUser->getAvatar('s')->getAvatarUrlPath()); } if (isset($this->prop['gender'])) { $vals['gender'] = $huijiUser->getOption('gender'); } if (isset($this->prop['status'])) { $us = new UserStatus($user); $vals['status'] = $us->getStatus(); } if (isset($this->prop['birthday'])) { $us = new UserStatus($user); $vals['birthday'] = $us->getBirthday(); } if (isset($this->prop['city'])) { $us = new UserStatus($user); $vals['city'] = $us->getCity(); } if (isset($this->prop['province'])) { $us = new UserStatus($user); $vals['province'] = $us->getProvince(); } if (isset($this->prop['followingcount'])) { $vals['followingcount'] = $huijiUser->getFollowingUsersCount(); } if (isset($this->prop['followercount'])) { $vals['followercount'] = $huijiUser->getFollowerCount(); } if (isset($this->prop['followingsitescount'])) { $vals['followingsitescount'] = $huijiUser->getFollowingSitesCount(); } if (isset($this->prop['stats'])) { $vals['stats'] = $huijiUser->getStats(); } if (isset($this->prop['level'])) { $vals['level'] = $huijiUser->getLevel()->getLevelNumber(); } if (isset($this->prop['followingsites'])) { $vals['followingsites'] = $huijiUser->getFollowingSites(true); } return $vals; }