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 ) {
79 $site = $siteLookup->getSite( $wikiID );
81 if ( !$site instanceof MediaWikiSite ) {
87 if ( $urlParts ===
null || !isset( $urlParts[
'path'] ) || !isset( $urlParts[
'host'] ) ) {
93 $path = $urlParts[
'path'];
94 if ( isset( $urlParts[
'query'] ) ) {
95 $path .=
'?' . $urlParts[
'query'];
98 $canonicalServer = $urlParts[
'scheme'] ??
'http';
99 $canonicalServer .=
'://' . $urlParts[
'host'];
100 if ( isset( $urlParts[
'port'] ) ) {
101 $canonicalServer .=
':' . $urlParts[
'port'];
104 return new WikiReference( $canonicalServer,
$path );
116 return $wiki ? $wiki->getDisplayName() : $wikiID;
147 if (
$url ===
false ) {
152 return $linkRenderer->makeExternalLink(
168 public static function getForeignURL( $wikiID, $page, $fragmentId =
null ) {
172 return $wiki->getFullUrl( $page, $fragmentId );
188 return $cache->getWithSetCallback(
189 $cache->makeGlobalKey(
'wikimap-canonical-urls' ),
198 $infoMap[$wikiId] = [
205 if ( $wikiReference ) {
206 $url = $wikiReference->getCanonicalServer();
224 if ( str_starts_with(
$url,
"$wgCanonicalServer/" ) ) {
231 if ( $urlPartsCheck ===
null
232 || !in_array( $urlPartsCheck[
'scheme'], [
'',
'http',
'https' ],
true )
237 static $relevantKeys = [
'host' => 1,
'port' => 1 ];
238 $urlPartsCheck = array_intersect_key( $urlPartsCheck, $relevantKeys );
240 foreach ( self::getCanonicalServerInfoForAllWikis() as $wikiId => $info ) {
241 $urlParts = $info[
'parts'];
242 if ( $urlParts ===
false ) {
246 $urlParts = array_intersect_key( $urlParts, $relevantKeys );
247 if ( $urlParts == $urlPartsCheck ) {
269 $domain = DatabaseDomain::newFromId( $domain );
275 if ( !in_array( $domain->getSchema(), [
null,
'mediawiki' ],
true ) ) {
279 return "{$domain->getDatabase()}-{$domain->getSchema()}-{$domain->getTablePrefix()}";
283 return strlen( $domain->getTablePrefix() )
284 ?
"{$domain->getDatabase()}-{$domain->getTablePrefix()}"
285 : (string)$domain->getDatabase();
321 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.