27 public static function getWiki( $wikiID ) {
28 $wikiReference = self::getWikiReferenceFromWgConf( $wikiID );
29 if ( $wikiReference ) {
30 return $wikiReference;
34 return self::getWikiWikiReferenceFromSites( $wikiID );
41 private static function getWikiReferenceFromWgConf( $wikiID ) {
43 '@phan-var \MediaWiki\Config\SiteConfiguration $wgConf';
47 [ $major, $minor ] =
$wgConf->siteFromDB( $wikiID );
48 if ( $major ===
null ) {
51 $server =
$wgConf->get(
'wgServer', $wikiID, $major,
52 [
'lang' => $minor,
'site' => $major ] );
54 $canonicalServer =
$wgConf->get(
'wgCanonicalServer', $wikiID, $major,
55 [
'lang' => $minor,
'site' => $major ] );
56 if ( $canonicalServer ===
false || $canonicalServer ===
null ) {
57 $canonicalServer = $server;
61 [
'lang' => $minor,
'site' => $major ] );
66 if ( !is_string( $canonicalServer ) || !is_string(
$path ) || !str_contains(
$path,
'$1' ) ) {
70 return new WikiReference( $canonicalServer,
$path, $server );
77 private static function getWikiWikiReferenceFromSites( $wikiID ) {
80 $site = $siteLookup->getSite( $wikiID );
82 if ( !$site instanceof MediaWikiSite ) {
87 $urlParts = $urlUtils->parse( $site->getPageUrl() );
88 if ( $urlParts ===
null || !isset( $urlParts[
'path'] ) || !isset( $urlParts[
'host'] ) ) {
94 $path = $urlParts[
'path'];
95 if ( isset( $urlParts[
'query'] ) ) {
96 $path .=
'?' . $urlParts[
'query'];
99 $canonicalServer = $urlParts[
'scheme'] ??
'http';
100 $canonicalServer .=
'://' . $urlParts[
'host'];
101 if ( isset( $urlParts[
'port'] ) ) {
102 $canonicalServer .=
':' . $urlParts[
'port'];
105 return new WikiReference( $canonicalServer,
$path );
117 return $wiki ? $wiki->getDisplayName() : $wikiID;
148 if (
$url ===
false ) {
153 return $linkRenderer->makeExternalLink(
169 public static function getForeignURL( $wikiID, $page, $fragmentId =
null ) {
173 return $wiki->getFullUrl( $page, $fragmentId );
189 return $cache->getWithSetCallback(
190 $cache->makeGlobalKey(
'wikimap-canonical-urls' ),
201 $infoMap[$wikiId] = [
208 if ( $wikiReference ) {
209 $url = $wikiReference->getCanonicalServer();
210 $infoMap[$wikiId] = [
'url' =>
$url,
'parts' => $urlUtils->parse(
$url ) ];
227 if ( str_starts_with(
$url,
"$wgCanonicalServer/" ) ) {
234 $urlPartsCheck = $urlUtils->parse(
$url );
235 if ( $urlPartsCheck ===
null
236 || !in_array( $urlPartsCheck[
'scheme'], [
'',
'http',
'https' ],
true )
241 static $relevantKeys = [
'host' => 1,
'port' => 1 ];
242 $urlPartsCheck = array_intersect_key( $urlPartsCheck, $relevantKeys );
244 foreach ( self::getCanonicalServerInfoForAllWikis() as $wikiId => $info ) {
245 $urlParts = $info[
'parts'];
246 if ( $urlParts ===
false ) {
250 $urlParts = array_intersect_key( $urlParts, $relevantKeys );
251 if ( $urlParts == $urlPartsCheck ) {
273 $domain = DatabaseDomain::newFromId( $domain );
279 if ( !in_array( $domain->getSchema(), [
null,
'mediawiki' ],
true ) ) {
283 return "{$domain->getDatabase()}-{$domain->getSchema()}-{$domain->getTablePrefix()}";
287 return strlen( $domain->getTablePrefix() )
288 ?
"{$domain->getDatabase()}-{$domain->getTablePrefix()}"
289 : (string)$domain->getDatabase();
325 return ( self::getCurrentWikiId() === $wikiId );
$wgConf
$wgConf hold the site configuration.
if(MW_ENTRY_POINT==='index') if(!defined( 'MW_NO_SESSION') &&MW_ENTRY_POINT !=='cli' $wgTitle
Parent class for all special pages.
static getTitleFor( $name, $subpage=false, $fragment='')
Get a localised Title object for a specified special page name If you don't need a full Title object,...
Class to handle database/schema/prefix specifications for IDatabase.
$wgDBprefix
Config variable stub for the DBprefix setting, for use by phpdoc and IDEs.
$wgLocalDatabases
Config variable stub for the LocalDatabases setting, for use by phpdoc and IDEs.
$wgDBmwschema
Config variable stub for the DBmwschema setting, for use by phpdoc and IDEs.
$wgDBname
Config variable stub for the DBname setting, for use by phpdoc and IDEs.
$wgCanonicalServer
Config variable stub for the CanonicalServer setting, for use by phpdoc and IDEs.