X-Git-Url: https://git.heureux-cyclage.org/?a=blobdiff_plain;f=includes%2FInterwiki.php;h=5a3b655643cc34bc1f0ad69630938d59547d901b;hb=f5afc708fbeb6351448169ba21aa1577087932cf;hp=96b0d36eb44b7ad5ecd29ae90dde56e9c36c588e;hpb=36d14ce34b41304f72b7b64825440cea65a0f5ee;p=lhc%2Fweb%2Fwiklou.git diff --git a/includes/Interwiki.php b/includes/Interwiki.php index 96b0d36eb4..5a3b655643 100644 --- a/includes/Interwiki.php +++ b/includes/Interwiki.php @@ -7,7 +7,8 @@ /** * The interwiki class * All information is loaded on creation when called by Interwiki::fetch( $prefix ). - * All work is done on slave, because this should *never* change (except during schema updates etc, which arent wiki-related) + * All work is done on slave, because this should *never* change (except during + * schema updates etc, which aren't wiki-related) */ class Interwiki { @@ -15,31 +16,33 @@ class Interwiki { protected static $smCache = array(); const CACHE_LIMIT = 100; // 0 means unlimited, any other value is max number of entries. - protected $mPrefix, $mURL, $mLocal, $mTrans; + protected $mPrefix, $mURL, $mAPI, $mWikiID, $mLocal, $mTrans; - function __construct( $prefix = null, $url = '', $local = 0, $trans = 0 ){ + public function __construct( $prefix = null, $url = '', $api = '', $wikiId = '', $local = 0, $trans = 0 ) { $this->mPrefix = $prefix; $this->mURL = $url; + $this->mAPI = $api; + $this->mWikiID = $wikiId; $this->mLocal = $local; $this->mTrans = $trans; } /** * Check whether an interwiki prefix exists - * - * @return bool Whether it exists - * @param $prefix string Interwiki prefix to use + * + * @param $prefix String: interwiki prefix to use + * @return Boolean: whether it exists */ - static public function isValidInterwiki( $prefix ){ + static public function isValidInterwiki( $prefix ) { $result = self::fetch( $prefix ); return (bool)$result; } /** * Fetch an Interwiki object - * + * + * @param $prefix String: interwiki prefix to use * @return Interwiki Object, or null if not valid - * @param $prefix string Interwiki prefix to use */ static public function fetch( $prefix ) { global $wgContLang; @@ -47,7 +50,7 @@ class Interwiki { return null; } $prefix = $wgContLang->lc( $prefix ); - if( isset( self::$smCache[$prefix] ) ){ + if( isset( self::$smCache[$prefix] ) ) { return self::$smCache[$prefix]; } global $wgInterwikiCache; @@ -55,13 +58,13 @@ class Interwiki { $iw = Interwiki::getInterwikiCached( $prefix ); } else { $iw = Interwiki::load( $prefix ); - if( !$iw ){ + if( !$iw ) { $iw = false; } } - if( self::CACHE_LIMIT && count( self::$smCache ) >= self::CACHE_LIMIT ){ + if( self::CACHE_LIMIT && count( self::$smCache ) >= self::CACHE_LIMIT ) { reset( self::$smCache ); - unset( self::$smCache[ key( self::$smCache ) ] ); + unset( self::$smCache[key( self::$smCache )] ); } self::$smCache[$prefix] = $iw; return $iw; @@ -72,8 +75,8 @@ class Interwiki { * * @note More logic is explained in DefaultSettings. * - * @param $prefix \type{\string} Interwiki prefix - * @return \type{\Interwiki} An interwiki object + * @param $prefix String: interwiki prefix + * @return Interwiki object */ protected static function getInterwikiCached( $prefix ) { $value = self::getInterwikiCacheEntry( $prefix ); @@ -95,36 +98,37 @@ class Interwiki { * * @note More logic is explained in DefaultSettings. * - * @param $prefix \type{\string} Database key - * @return \type{\string) The entry + * @param $prefix String: database key + * @return String: the entry */ - protected static function getInterwikiCacheEntry( $prefix ){ + protected static function getInterwikiCacheEntry( $prefix ) { global $wgInterwikiCache, $wgInterwikiScopes, $wgInterwikiFallbackSite; static $db, $site; wfDebug( __METHOD__ . "( $prefix )\n" ); - if( !$db ){ - $db = dba_open( $wgInterwikiCache, 'r', 'cdb' ); + if( !$db ) { + $db = CdbReader::open( $wgInterwikiCache ); } /* Resolve site name */ - if( $wgInterwikiScopes>=3 && !$site ) { - $site = dba_fetch( '__sites:' . wfWikiID(), $db ); - if ( $site == '' ){ + if( $wgInterwikiScopes >= 3 && !$site ) { + $site = $db->get( '__sites:' . wfWikiID() ); + if ( $site == '' ) { $site = $wgInterwikiFallbackSite; } } - $value = dba_fetch( wfMemcKey( $prefix ), $db ); + $value = $db->get( wfMemcKey( $prefix ) ); // Site level if ( $value == '' && $wgInterwikiScopes >= 3 ) { - $value = dba_fetch( "_{$site}:{$prefix}", $db ); + $value = $db->get( "_{$site}:{$prefix}" ); } // Global Level if ( $value == '' && $wgInterwikiScopes >= 2 ) { - $value = dba_fetch( "__global:{$prefix}", $db ); + $value = $db->get( "__global:{$prefix}" ); } - if ( $value == 'undef' ) + if ( $value == 'undef' ) { $value = ''; + } return $value; } @@ -133,17 +137,16 @@ class Interwiki { * Load the interwiki, trying first memcached then the DB * * @param $prefix The interwiki prefix - * @return bool The prefix is valid - * @static + * @return Boolean: the prefix is valid */ protected static function load( $prefix ) { global $wgMemc, $wgInterwikiExpiry; $key = wfMemcKey( 'interwiki', $prefix ); $mc = $wgMemc->get( $key ); - $iw = false; - if( $mc && is_array( $mc ) ){ // is_array is hack for old keys + + if( $mc && is_array( $mc ) ) { // is_array is hack for old keys $iw = Interwiki::loadFromArray( $mc ); - if( $iw ){ + if( $iw ) { return $iw; } } @@ -154,7 +157,12 @@ class Interwiki { __METHOD__ ) ); $iw = Interwiki::loadFromArray( $row ); if ( $iw ) { - $mc = array( 'iw_url' => $iw->mURL, 'iw_local' => $iw->mLocal, 'iw_trans' => $iw->mTrans ); + $mc = array( + 'iw_url' => $iw->mURL, + 'iw_api' => $iw->mAPI, + 'iw_local' => $iw->mLocal, + 'iw_trans' => $iw->mTrans + ); $wgMemc->add( $key, $mc, $wgInterwikiExpiry ); return $iw; } @@ -165,16 +173,18 @@ class Interwiki { /** * Fill in member variables from an array (e.g. memcached result, Database::fetchRow, etc) * - * @return bool Whether everything was there - * @param $res ResultWrapper Row from the interwiki table - * @static + * @param $mc Associative array: row from the interwiki table + * @return Boolean: whether everything was there */ protected static function loadFromArray( $mc ) { - if( isset( $mc['iw_url'] ) && isset( $mc['iw_local'] ) && isset( $mc['iw_trans'] ) ){ + if( isset( $mc['iw_url'] ) && isset( $mc['iw_local'] ) && isset( $mc['iw_trans'] ) ) { $iw = new Interwiki(); $iw->mURL = $mc['iw_url']; $iw->mLocal = $mc['iw_local']; $iw->mTrans = $mc['iw_trans']; + $iw->mAPI = isset( $mc['iw_api'] ) ? $mc['iw_api'] : ''; + $iw->mWikiID = isset( $mc['iw_wikiid'] ) ? $mc['iw_wikiid'] : ''; + return $iw; } return false; @@ -182,24 +192,75 @@ class Interwiki { /** * Get the URL for a particular title (or with $1 if no title given) - * - * @param $title string What text to put for the article name - * @return string The URL + * + * @param $title String: what text to put for the article name + * @return String: the URL */ - function getURL( $title = null ){ + public function getURL( $title = null ) { $url = $this->mURL; - if( $title != null ){ + if( $title != null ) { $url = str_replace( "$1", $title, $url ); } return $url; } - function isLocal(){ + /** + * Get the API URL for this wiki + * + * @return String: the URL + */ + public function getAPI() { + return $this->mAPI; + } + + /** + * Get the DB name for this wiki + * + * @return String: the DB name + */ + public function getWikiID() { + return $this->mWikiID; + } + + /** + * Is this a local link from a sister project, or is + * it something outside, like Google + * + * @return Boolean + */ + public function isLocal() { return $this->mLocal; } - function isTranscludable(){ + /** + * Can pages from this wiki be transcluded? + * Still requires $wgEnableScaryTransclusion + * + * @return Boolean + */ + public function isTranscludable() { return $this->mTrans; } + /** + * Get the name for the interwiki site + * + * @return String + */ + public function getName() { + $key = 'interwiki-name-' . $this->mPrefix; + $msg = wfMsgForContent( $key ); + return wfEmptyMsg( $key, $msg ) ? '' : $msg; + } + + /** + * Get a description for this interwiki + * + * @return String + */ + public function getDescription() { + $key = 'interwiki-desc-' . $this->mPrefix; + $msg = wfMsgForContent( $key ); + return wfEmptyMsg( $key, $msg ) ? '' : $msg; + } }