X-Git-Url: https://git.heureux-cyclage.org/?a=blobdiff_plain;f=includes%2Fapi%2FApiQuerySiteinfo.php;h=e7102e00115f9ed7bb6179e31271ff4ddf28f654;hb=97f2db74a0e55fe71214e0eb3275d8428c9d0889;hp=53ef2902103c80df0b22d6ace369e749b252a535;hpb=527332491fcb8def21063e0399c04cf6ec3f4a55;p=lhc%2Fweb%2Fwiklou.git diff --git a/includes/api/ApiQuerySiteinfo.php b/includes/api/ApiQuerySiteinfo.php index 53ef290210..e7102e0011 100644 --- a/includes/api/ApiQuerySiteinfo.php +++ b/includes/api/ApiQuerySiteinfo.php @@ -1,9 +1,8 @@ @gmail.com * @@ -21,13 +20,10 @@ * with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * http://www.gnu.org/copyleft/gpl.html + * + * @file */ -if ( !defined( 'MEDIAWIKI' ) ) { - // Eclipse helper - will be ignored in production - require_once( 'ApiQueryBase.php' ); -} - /** * A query action to return meta information about the wiki site. * @@ -42,6 +38,7 @@ class ApiQuerySiteinfo extends ApiQueryBase { public function execute() { $params = $this->extractRequestParams(); $done = array(); + $fit = false; foreach ( $params['prop'] as $p ) { switch ( $p ) { case 'general': @@ -84,6 +81,18 @@ class ApiQuerySiteinfo extends ApiQueryBase { case 'languages': $fit = $this->appendLanguages( $p ); break; + case 'skins': + $fit = $this->appendSkins( $p ); + break; + case 'extensiontags': + $fit = $this->appendExtensionTags( $p ); + break; + case 'functionhooks': + $fit = $this->appendFunctionHooks( $p ); + break; + case 'showhooks': + $fit = $this->appendSubscribedHooks( $p ); + break; default: ApiBase::dieDebug( __METHOD__, "Unknown prop=$p" ); } @@ -104,7 +113,7 @@ class ApiQuerySiteinfo extends ApiQueryBase { $data = array(); $mainPage = Title::newMainPage(); $data['mainpage'] = $mainPage->getPrefixedText(); - $data['base'] = $mainPage->getFullUrl(); + $data['base'] = wfExpandUrl( $mainPage->getFullUrl(), PROTO_CURRENT ); $data['sitename'] = $GLOBALS['wgSitename']; $data['generator'] = "MediaWiki {$GLOBALS['wgVersion']}"; $data['phpversion'] = phpversion(); @@ -125,6 +134,23 @@ class ApiQuerySiteinfo extends ApiQueryBase { } $data['rights'] = $GLOBALS['wgRightsText']; $data['lang'] = $GLOBALS['wgLanguageCode']; + + $fallbacks = array(); + foreach( $wgContLang->getFallbackLanguages() as $code ) { + $fallbacks[] = array( 'code' => $code ); + } + $data['fallback'] = $fallbacks; + $this->getResult()->setIndexedTagName( $data['fallback'], 'lang' ); + + if( $wgContLang->hasVariants() ) { + $variants = array(); + foreach( $wgContLang->getVariants() as $code ) { + $variants[] = array( 'code' => $code ); + } + $data['variants'] = $variants; + $this->getResult()->setIndexedTagName( $data['variants'], 'lang' ); + } + if ( $wgContLang->isRTL() ) { $data['rtl'] = ''; } @@ -156,6 +182,14 @@ class ApiQuerySiteinfo extends ApiQueryBase { $data['wikiid'] = wfWikiID(); $data['time'] = wfTimestamp( TS_ISO_8601, time() ); + if ( $GLOBALS['wgMiserMode'] ) { + $data['misermode'] = ''; + } + + $data['maxuploadsize'] = UploadBase::getMaxUploadSize(); + + wfRunHooks( 'APIQuerySiteInfoGeneralInfo', array( $this, &$data ) ); + return $this->getResult()->addValue( 'query', $property, $data ); } @@ -181,6 +215,10 @@ class ApiQuerySiteinfo extends ApiQueryBase { if ( MWNamespace::isContent( $ns ) ) { $data[$ns]['content'] = ''; } + + if ( MWNamespace::isNonincludable( $ns ) ) { + $data[$ns]['nonincludable'] = ''; + } } $this->getResult()->setIndexedTagName( $data, 'ns' ); @@ -211,8 +249,7 @@ class ApiQuerySiteinfo extends ApiQueryBase { protected function appendSpecialPageAliases( $property ) { global $wgContLang; $data = array(); - foreach ( $wgContLang->getSpecialPageAliases() as $specialpage => $aliases ) - { + foreach ( $wgContLang->getSpecialPageAliases() as $specialpage => $aliases ) { $arr = array( 'realname' => $specialpage, 'aliases' => $aliases ); $this->getResult()->setIndexedTagName( $arr['aliases'], 'alias' ); $data[] = $arr; @@ -238,35 +275,40 @@ class ApiQuerySiteinfo extends ApiQueryBase { } protected function appendInterwikiMap( $property, $filter ) { - $this->resetQueryParams(); - $this->addTables( 'interwiki' ); - $this->addFields( array( 'iw_prefix', 'iw_local', 'iw_url' ) ); - + $local = null; if ( $filter === 'local' ) { - $this->addWhere( 'iw_local = 1' ); + $local = 1; } elseif ( $filter === '!local' ) { - $this->addWhere( 'iw_local = 0' ); + $local = 0; } elseif ( $filter ) { ApiBase::dieDebug( __METHOD__, "Unknown filter=$filter" ); } - $this->addOption( 'ORDER BY', 'iw_prefix' ); - - $res = $this->select( __METHOD__ ); + $params = $this->extractRequestParams(); + $langCode = isset( $params['inlanguagecode'] ) ? $params['inlanguagecode'] : ''; + $langNames = Language::fetchLanguageNames( $langCode ); + $getPrefixes = Interwiki::getAllPrefixes( $local ); $data = array(); - $langNames = Language::getLanguageNames(); - foreach ( $res as $row ) { + + foreach ( $getPrefixes as $row ) { + $prefix = $row['iw_prefix']; $val = array(); - $val['prefix'] = $row->iw_prefix; - if ( $row->iw_local == '1' ) { + $val['prefix'] = $prefix; + if ( $row['iw_local'] == '1' ) { $val['local'] = ''; } - // $val['trans'] = intval( $row->iw_trans ); // should this be exposed? - if ( isset( $langNames[$row->iw_prefix] ) ) { - $val['language'] = $langNames[$row->iw_prefix]; + // $val['trans'] = intval( $row['iw_trans'] ); // should this be exposed? + if ( isset( $langNames[$prefix] ) ) { + $val['language'] = $langNames[$prefix]; + } + $val['url'] = wfExpandUrl( $row['iw_url'], PROTO_CURRENT ); + if( isset( $row['iw_wikiid'] ) ) { + $val['wikiid'] = $row['iw_wikiid']; + } + if( isset( $row['iw_api'] ) ) { + $val['api'] = $row['iw_api']; } - $val['url'] = $row->iw_url; $data[] = $val; } @@ -278,12 +320,12 @@ class ApiQuerySiteinfo extends ApiQueryBase { protected function appendDbReplLagInfo( $property, $includeAll ) { global $wgShowHostnames; $data = array(); + $lb = wfGetLB(); if ( $includeAll ) { if ( !$wgShowHostnames ) { $this->dieUsage( 'Cannot view all servers info unless $wgShowHostnames is true', 'includeAllDenied' ); } - $lb = wfGetLB(); $lags = $lb->getLagTimes(); foreach ( $lags as $i => $lag ) { $data[] = array( @@ -292,9 +334,11 @@ class ApiQuerySiteinfo extends ApiQueryBase { ); } } else { - list( $host, $lag ) = wfGetLB()->getMaxLag(); + list( $host, $lag, $index ) = $lb->getMaxLag(); $data[] = array( - 'host' => $wgShowHostnames ? $host : '', + 'host' => $wgShowHostnames + ? $lb->getServerName( $index ) + : '', 'lag' => intval( $lag ) ); } @@ -323,37 +367,47 @@ class ApiQuerySiteinfo extends ApiQueryBase { protected function appendUserGroups( $property, $numberInGroup ) { global $wgGroupPermissions, $wgAddGroups, $wgRemoveGroups, $wgGroupsAddToSelf, $wgGroupsRemoveFromSelf; - + $data = array(); + $result = $this->getResult(); foreach ( $wgGroupPermissions as $group => $permissions ) { $arr = array( 'name' => $group, 'rights' => array_keys( $permissions, true ), ); + if ( $numberInGroup ) { - $arr['number'] = SiteStats::numberInGroup( $group ); + global $wgAutopromote; + + if ( $group == 'user' ) { + $arr['number'] = SiteStats::users(); + + // '*' and autopromote groups have no size + } elseif ( $group !== '*' && !isset( $wgAutopromote[$group] ) ) { + $arr['number'] = SiteStats::numberInGroup( $group ); + } } - + $groupArr = array( - 'add' => &$wgAddGroups, - 'remove' => &$wgRemoveGroups, - 'add-self' => &$wgGroupsAddToSelf, - 'remove-self' => &$wgGroupsRemoveFromSelf + 'add' => $wgAddGroups, + 'remove' => $wgRemoveGroups, + 'add-self' => $wgGroupsAddToSelf, + 'remove-self' => $wgGroupsRemoveFromSelf ); - - foreach( $groupArr as $type => $rights ) { - if( isset( $rights[$group] ) ) { + + foreach ( $groupArr as $type => $rights ) { + if ( isset( $rights[$group] ) ) { $arr[$type] = $rights[$group]; - $this->getResult()->setIndexedTagName( $arr[$type], 'group' ); + $result->setIndexedTagName( $arr[$type], 'group' ); } } - - $this->getResult()->setIndexedTagName( $arr['rights'], 'permission' ); + + $result->setIndexedTagName( $arr['rights'], 'permission' ); $data[] = $arr; } - - $this->getResult()->setIndexedTagName( $data, 'group' ); - return $this->getResult()->addValue( 'query', $property, $data ); + + $result->setIndexedTagName( $data, 'group' ); + return $result->addValue( 'query', $property, $data ); } protected function appendFileExtensions( $property ) { @@ -413,11 +467,10 @@ class ApiQuerySiteinfo extends ApiQueryBase { return $this->getResult()->addValue( 'query', $property, $data ); } - protected function appendRightsInfo( $property ) { global $wgRightsPage, $wgRightsUrl, $wgRightsText; $title = Title::newFromText( $wgRightsPage ); - $url = $title ? $title->getFullURL() : $wgRightsUrl; + $url = $title ? wfExpandUrl( $title->getFullURL(), PROTO_CURRENT ) : $wgRightsUrl; $text = $wgRightsText; if ( !$text && $title ) { $text = $title->getPrefixedText(); @@ -432,8 +485,13 @@ class ApiQuerySiteinfo extends ApiQueryBase { } public function appendLanguages( $property ) { + $params = $this->extractRequestParams(); + $langCode = isset( $params['inlanguagecode'] ) ? $params['inlanguagecode'] : ''; + $langNames = Language::fetchLanguageNames( $langCode ); + $data = array(); - foreach ( Language::getLanguageNames() as $code => $name ) { + + foreach ( $langNames as $code => $name ) { $lang = array( 'code' => $code ); ApiResult::setContent( $lang, $name ); $data[] = $lang; @@ -442,6 +500,57 @@ class ApiQuerySiteinfo extends ApiQueryBase { return $this->getResult()->addValue( 'query', $property, $data ); } + public function appendSkins( $property ) { + $data = array(); + foreach ( Skin::getSkinNames() as $name => $displayName ) { + $skin = array( 'code' => $name ); + ApiResult::setContent( $skin, $displayName ); + $data[] = $skin; + } + $this->getResult()->setIndexedTagName( $data, 'skin' ); + return $this->getResult()->addValue( 'query', $property, $data ); + } + + public function appendExtensionTags( $property ) { + global $wgParser; + $wgParser->firstCallInit(); + $tags = array_map( array( $this, 'formatParserTags'), $wgParser->getTags() ); + $this->getResult()->setIndexedTagName( $tags, 't' ); + return $this->getResult()->addValue( 'query', $property, $tags ); + } + + public function appendFunctionHooks( $property ) { + global $wgParser; + $wgParser->firstCallInit(); + $hooks = $wgParser->getFunctionHooks(); + $this->getResult()->setIndexedTagName( $hooks, 'h' ); + return $this->getResult()->addValue( 'query', $property, $hooks ); + } + + private function formatParserTags( $item ) { + return "<{$item}>"; + } + + public function appendSubscribedHooks( $property ) { + global $wgHooks; + $myWgHooks = $wgHooks; + ksort( $myWgHooks ); + + $data = array(); + foreach ( $myWgHooks as $hook => $hooks ) { + $arr = array( + 'name' => $hook, + 'subscribers' => array_map( array( 'SpecialVersion', 'arrayToString' ), $hooks ), + ); + + $this->getResult()->setIndexedTagName( $arr['subscribers'], 's' ); + $data[] = $arr; + } + + $this->getResult()->setIndexedTagName( $data, 'hook' ); + return $this->getResult()->addValue( 'query', $property, $data ); + } + public function getCacheMode( $params ) { return 'public'; } @@ -465,6 +574,10 @@ class ApiQuerySiteinfo extends ApiQueryBase { 'fileextensions', 'rightsinfo', 'languages', + 'skins', + 'extensiontags', + 'functionhooks', + 'showhooks', ) ), 'filteriw' => array( @@ -475,30 +588,37 @@ class ApiQuerySiteinfo extends ApiQueryBase { ), 'showalldb' => false, 'numberingroup' => false, + 'inlanguagecode' => null, ); } public function getParamDescription() { + $p = $this->getModulePrefix(); return array( 'prop' => array( 'Which sysinfo properties to get:', - ' general - Overall system information', - ' namespaces - List of registered namespaces and their canonical names', - ' namespacealiases - List of registered namespace aliases', - ' specialpagealiases - List of special page aliases', - ' magicwords - List of magic words and their aliases', - ' statistics - Returns site statistics', - ' interwikimap - Returns interwiki map (optionally filtered)', - ' dbrepllag - Returns database server with the highest replication lag', - ' usergroups - Returns user groups and the associated permissions', - ' extensions - Returns extensions installed on the wiki', - ' fileextensions - Returns list of file extensions allowed to be uploaded', - ' rightsinfo - Returns wiki rights (license) information if available', - ' languages - Returns a list of languages MediaWiki supports', + ' general - Overall system information', + ' namespaces - List of registered namespaces and their canonical names', + ' namespacealiases - List of registered namespace aliases', + ' specialpagealiases - List of special page aliases', + ' magicwords - List of magic words and their aliases', + ' statistics - Returns site statistics', + " interwikimap - Returns interwiki map (optionally filtered, (optionally localised by using {$p}inlanguagecode))", + ' dbrepllag - Returns database server with the highest replication lag', + ' usergroups - Returns user groups and the associated permissions', + ' extensions - Returns extensions installed on the wiki', + ' fileextensions - Returns list of file extensions allowed to be uploaded', + ' rightsinfo - Returns wiki rights (license) information if available', + " languages - Returns a list of languages MediaWiki supports (optionally localised by using {$p}inlanguagecode)", + ' skins - Returns a list of all enabled skins', + ' extensiontags - Returns a list of parser extension tags', + ' functionhooks - Returns a list of parser function hooks', + ' showhooks - Returns a list of all subscribed hooks (contents of $wgHooks)' ), 'filteriw' => 'Return only local or only nonlocal entries of the interwiki map', 'showalldb' => 'List all database servers, not just the one lagging the most', 'numberingroup' => 'Lists the number of users in user groups', + 'inlanguagecode' => 'Language code for localised language names (best effort, use CLDR extension)', ); } @@ -512,14 +632,18 @@ class ApiQuerySiteinfo extends ApiQueryBase { ) ); } - protected function getExamples() { + public function getExamples() { return array( 'api.php?action=query&meta=siteinfo&siprop=general|namespaces|namespacealiases|statistics', 'api.php?action=query&meta=siteinfo&siprop=interwikimap&sifilteriw=local', - 'api.php?action=query&meta=siteinfo&siprop=dbrepllag&sishowalldb', + 'api.php?action=query&meta=siteinfo&siprop=dbrepllag&sishowalldb=', ); } + public function getHelpUrls() { + return 'https://www.mediawiki.org/wiki/API:Meta#siteinfo_.2F_si'; + } + public function getVersion() { return __CLASS__ . ': $Id$'; }