2004-02-18 02:15:00 +00:00
|
|
|
<?php
|
2003-04-14 23:10:40 +00:00
|
|
|
# The main wiki script and things like database
|
|
|
|
|
# conversion and maintenance scripts all share a
|
|
|
|
|
# common setup of including lots of classes and
|
|
|
|
|
# setting up a few globals.
|
|
|
|
|
#
|
|
|
|
|
|
2004-03-20 15:03:26 +00:00
|
|
|
global $wgProfiling, $wgProfileSampleRate, $wgIP, $wgUseSquid;
|
|
|
|
|
|
2003-10-25 08:01:33 +00:00
|
|
|
if( !isset( $wgProfiling ) )
|
|
|
|
|
$wgProfiling = false;
|
|
|
|
|
|
2003-11-18 23:49:11 +00:00
|
|
|
if ( $wgProfiling and (0 == rand() % $wgProfileSampleRate ) ) {
|
2004-06-09 01:25:31 +00:00
|
|
|
require_once( 'Profiling.php' );
|
2003-10-25 08:01:33 +00:00
|
|
|
} else {
|
2004-06-08 02:32:56 +00:00
|
|
|
function wfProfileIn( $fn = '' ) {}
|
|
|
|
|
function wfProfileOut( $fn = '' ) {}
|
2003-10-25 08:01:33 +00:00
|
|
|
function wfGetProfilingOutput( $s, $e ) {}
|
|
|
|
|
function wfProfileClose() {}
|
|
|
|
|
}
|
|
|
|
|
|
2004-01-30 17:07:50 +00:00
|
|
|
/* collect the originating ips */
|
2004-06-09 01:25:31 +00:00
|
|
|
if( $wgUseSquid && isset( $_SERVER['HTTP_X_FORWARDED_FOR'] ) ) {
|
2004-01-31 05:17:54 +00:00
|
|
|
# If the web server is behind a reverse proxy, we need to find
|
|
|
|
|
# out where our requests are really coming from.
|
2004-06-09 01:25:31 +00:00
|
|
|
$hopips = array_map( 'trim', explode( ',', $_SERVER['HTTP_X_FORWARDED_FOR'] ) );
|
2004-03-08 18:44:20 +00:00
|
|
|
|
|
|
|
|
while(in_array(trim(end($hopips)), $wgSquidServers)){
|
|
|
|
|
array_pop($hopips);
|
|
|
|
|
}
|
|
|
|
|
$wgIP = trim(end($hopips));
|
|
|
|
|
} else {
|
2004-06-09 01:25:31 +00:00
|
|
|
$wgIP = getenv('REMOTE_ADDR');
|
2004-01-30 17:07:50 +00:00
|
|
|
}
|
|
|
|
|
|
2004-03-08 18:44:20 +00:00
|
|
|
|
2004-06-09 01:25:31 +00:00
|
|
|
$fname = 'Setup.php';
|
2003-10-25 08:01:33 +00:00
|
|
|
wfProfileIn( $fname );
|
2003-11-20 13:40:30 +00:00
|
|
|
global $wgUseDynamicDates;
|
2004-06-09 01:25:31 +00:00
|
|
|
wfProfileIn( $fname.'-includes' );
|
|
|
|
|
|
|
|
|
|
require_once( 'GlobalFunctions.php' );
|
|
|
|
|
require_once( 'Namespace.php' );
|
|
|
|
|
require_once( 'RecentChange.php' );
|
|
|
|
|
require_once( 'Skin.php' );
|
|
|
|
|
require_once( 'OutputPage.php' );
|
|
|
|
|
require_once( 'User.php' );
|
|
|
|
|
require_once( 'LinkCache.php' );
|
|
|
|
|
require_once( 'Title.php' );
|
|
|
|
|
require_once( 'Article.php' );
|
|
|
|
|
require_once( 'MagicWord.php' );
|
|
|
|
|
require_once( 'memcached-client.php' );
|
|
|
|
|
require_once( 'Block.php' );
|
|
|
|
|
require_once( 'SearchEngine.php' );
|
|
|
|
|
require_once( 'DifferenceEngine.php' );
|
|
|
|
|
require_once( 'MessageCache.php' );
|
|
|
|
|
require_once( 'BlockCache.php' );
|
|
|
|
|
require_once( 'Parser.php' );
|
|
|
|
|
require_once( 'ParserCache.php' );
|
|
|
|
|
require_once( 'WebRequest.php' );
|
2004-06-15 15:00:54 +00:00
|
|
|
require_once( 'LoadBalancer.php' );
|
2004-05-15 03:36:39 +00:00
|
|
|
|
2004-03-08 09:09:35 +00:00
|
|
|
$wgRequest = new WebRequest();
|
|
|
|
|
|
2003-08-11 13:53:20 +00:00
|
|
|
|
2004-05-09 10:37:00 +00:00
|
|
|
|
2004-06-09 01:25:31 +00:00
|
|
|
wfProfileOut( $fname.'-includes' );
|
|
|
|
|
wfProfileIn( $fname.'-memcached' );
|
2003-04-14 23:10:40 +00:00
|
|
|
global $wgUser, $wgLang, $wgOut, $wgTitle;
|
|
|
|
|
global $wgArticle, $wgDeferredUpdateList, $wgLinkCache;
|
2003-10-20 13:39:40 +00:00
|
|
|
global $wgMemc, $wgMagicWords, $wgMwRedir, $wgDebugLogFile;
|
2003-12-14 14:29:35 +00:00
|
|
|
global $wgMessageCache, $wgUseMemCached, $wgUseDatabaseMessages;
|
2004-01-10 14:18:05 +00:00
|
|
|
global $wgMsgCacheExpiry, $wgDBname, $wgCommandLineMode;
|
2004-06-15 15:00:54 +00:00
|
|
|
global $wgBlockCache, $wgParserCache, $wgParser, $wgDBConnections;
|
|
|
|
|
global $wgLoadBalancer, $wgDBservers, $wgDBloads, $wgDBuser, $wgDBpassword;
|
2004-02-14 12:37:25 +00:00
|
|
|
|
|
|
|
|
# Useful debug output
|
2004-03-23 10:15:26 +00:00
|
|
|
if ( $wgCommandLineMode ) {
|
2004-04-14 06:15:46 +00:00
|
|
|
# wfDebug( '"' . implode( '" "', $argv ) . '"' );
|
2004-06-09 01:25:31 +00:00
|
|
|
} elseif ( function_exists( 'getallheaders' ) ) {
|
2004-02-14 12:37:25 +00:00
|
|
|
wfDebug( "\nStart request\n" );
|
2004-03-08 01:51:32 +00:00
|
|
|
wfDebug( $_SERVER['REQUEST_METHOD'] . ' ' . $_SERVER['REQUEST_URI'] . "\n" );
|
2004-02-14 12:37:25 +00:00
|
|
|
$headers = getallheaders();
|
|
|
|
|
foreach ($headers as $name => $value) {
|
|
|
|
|
wfDebug( "$name: $value\n" );
|
|
|
|
|
}
|
|
|
|
|
wfDebug( "\n" );
|
|
|
|
|
} else {
|
2004-03-08 01:51:32 +00:00
|
|
|
wfDebug( $_SERVER['REQUEST_METHOD'] . ' ' . $_SERVER['REQUEST_URI'] . "\n" );
|
2004-03-06 01:49:16 +00:00
|
|
|
}
|
2003-08-11 13:53:20 +00:00
|
|
|
|
2004-03-06 01:49:16 +00:00
|
|
|
# Set up Memcached
|
|
|
|
|
#
|
2004-01-24 22:58:19 +00:00
|
|
|
class MemCachedClientforWiki extends memcached {
|
2004-01-25 07:11:42 +00:00
|
|
|
function _debugprint( $text ) {
|
2003-08-11 13:53:20 +00:00
|
|
|
wfDebug( "memcached: $text\n" );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2004-01-25 00:53:07 +00:00
|
|
|
# FakeMemCachedClient imitates the API of memcached-client v. 0.1.2.
|
|
|
|
|
# It acts as a memcached server with no RAM, that is, all objects are
|
|
|
|
|
# cleared the moment they are set. All set operations succeed and all
|
|
|
|
|
# get operations return null.
|
|
|
|
|
|
|
|
|
|
class FakeMemCachedClient {
|
|
|
|
|
function add ($key, $val, $exp = 0) { return true; }
|
|
|
|
|
function decr ($key, $amt=1) { return null; }
|
|
|
|
|
function delete ($key, $time = 0) { return false; }
|
|
|
|
|
function disconnect_all () { }
|
|
|
|
|
function enable_compress ($enable) { }
|
|
|
|
|
function forget_dead_hosts () { }
|
|
|
|
|
function get ($key) { return null; }
|
|
|
|
|
function get_multi ($keys) { return array_pad(array(), count($keys), null); }
|
|
|
|
|
function incr ($key, $amt=1) { return null; }
|
|
|
|
|
function replace ($key, $value, $exp=0) { return false; }
|
|
|
|
|
function run_command ($sock, $cmd) { return null; }
|
|
|
|
|
function set ($key, $value, $exp=0){ return true; }
|
|
|
|
|
function set_compress_threshold ($thresh){ }
|
|
|
|
|
function set_debug ($dbg) { }
|
|
|
|
|
function set_servers ($list) { }
|
|
|
|
|
}
|
|
|
|
|
|
2003-08-11 13:53:20 +00:00
|
|
|
if( $wgUseMemCached ) {
|
2004-01-25 00:53:07 +00:00
|
|
|
$wgMemc = new MemCachedClientforWiki( array('persistant' => true) );
|
2003-08-11 13:53:20 +00:00
|
|
|
$wgMemc->set_servers( $wgMemCachedServers );
|
2003-08-13 11:11:50 +00:00
|
|
|
$wgMemc->set_debug( $wgMemCachedDebug );
|
2003-10-20 13:39:40 +00:00
|
|
|
|
|
|
|
|
# Test it to see if it's working
|
2003-10-21 13:01:49 +00:00
|
|
|
# This is necessary because otherwise wfMsg would be extremely inefficient
|
2004-06-09 01:25:31 +00:00
|
|
|
if ( !$wgMemc->set( 'test', '', 0 ) ) {
|
2004-01-24 22:58:19 +00:00
|
|
|
wfDebug( "Memcached failed setup test - connection error?\n" );
|
2003-10-21 13:01:49 +00:00
|
|
|
$wgUseMemCached = false;
|
2004-01-25 00:53:07 +00:00
|
|
|
$wgMemc = new FakeMemCachedClient();
|
2003-10-20 13:39:40 +00:00
|
|
|
}
|
2004-05-09 05:12:55 +00:00
|
|
|
$messageMemc = &$wgMemc;
|
2004-01-25 00:53:07 +00:00
|
|
|
} else {
|
|
|
|
|
$wgMemc = new FakeMemCachedClient();
|
2004-05-09 05:12:55 +00:00
|
|
|
|
|
|
|
|
# Give the message cache a separate cache in the DB.
|
|
|
|
|
# This is a speedup over separately querying every message used
|
2004-06-09 01:25:31 +00:00
|
|
|
require_once( 'ObjectCache.php' );
|
|
|
|
|
$messageMemc = new MediaWikiBagOStuff('objectcache');
|
2003-08-11 13:53:20 +00:00
|
|
|
}
|
2003-11-21 02:43:12 +00:00
|
|
|
|
2004-06-09 01:25:31 +00:00
|
|
|
wfProfileOut( $fname.'-memcached' );
|
2004-06-15 15:00:54 +00:00
|
|
|
wfProfileIn( $fname.'-database' );
|
|
|
|
|
|
|
|
|
|
if ( !$wgDBservers ) {
|
|
|
|
|
$wgDBservers = array( $wgDBserver );
|
|
|
|
|
$wgDBloads = array( 1 );
|
|
|
|
|
}
|
|
|
|
|
$wgLoadBalancer = LoadBalancer::newFromParams( $wgDBservers, $wgDBloads, $wgDBuser, $wgDBpassword, $wgDBname );
|
|
|
|
|
$wgLoadBalancer->force(0);
|
|
|
|
|
|
|
|
|
|
wfProfileOut( $fname.'-database' );
|
2004-06-09 01:25:31 +00:00
|
|
|
wfProfileIn( $fname.'-language' );
|
|
|
|
|
require_once( 'languages/Language.php' );
|
2003-08-30 09:39:34 +00:00
|
|
|
|
2004-01-07 13:05:27 +00:00
|
|
|
$wgMessageCache = new MessageCache;
|
2003-12-14 14:29:35 +00:00
|
|
|
|
2004-06-09 01:25:31 +00:00
|
|
|
$wgLangClass = 'Language' . ucfirst( $wgLanguageCode );
|
2004-06-11 02:47:41 +00:00
|
|
|
if( ! class_exists( $wgLangClass ) || ($wgLanguageCode == 'en' && !$wgUseLatin1) ) {
|
|
|
|
|
# Default to English/UTF-8
|
2004-06-09 01:25:31 +00:00
|
|
|
require_once( 'languages/LanguageUtf8.php' );
|
|
|
|
|
$wgLangClass = 'LanguageUtf8';
|
2003-04-14 23:10:40 +00:00
|
|
|
}
|
2004-01-07 13:05:27 +00:00
|
|
|
|
2003-04-14 23:10:40 +00:00
|
|
|
$wgLang = new $wgLangClass();
|
2004-01-07 13:05:27 +00:00
|
|
|
if ( !is_object($wgLang) ) {
|
|
|
|
|
print "No language class ($wgLang)\N";
|
|
|
|
|
}
|
2004-06-11 02:47:41 +00:00
|
|
|
|
|
|
|
|
if( $wgUseLatin1 && $wgLanguageCode != 'en' ) {
|
|
|
|
|
# For non-UTF-8 non-English.
|
|
|
|
|
require_once( 'languages/LanguageLatin1.php' );
|
|
|
|
|
$xxx = new LanguageLatin1( $wgLang );
|
|
|
|
|
unset( $wgLang );
|
|
|
|
|
$wgLang = $xxx;
|
|
|
|
|
}
|
2004-06-09 01:25:31 +00:00
|
|
|
wfProfileOut( $fname.'-language' );
|
|
|
|
|
wfProfileIn( $fname.'-MessageCache' );
|
2004-06-04 02:44:58 +00:00
|
|
|
|
2004-05-09 05:12:55 +00:00
|
|
|
$wgMessageCache->initialise( $messageMemc, $wgUseDatabaseMessages, $wgMsgCacheExpiry, $wgDBname );
|
2003-04-14 23:10:40 +00:00
|
|
|
|
2004-06-09 01:25:31 +00:00
|
|
|
wfProfileOut( $fname.'-MessageCache' );
|
|
|
|
|
wfProfileIn( $fname.'-OutputPage' );
|
2004-06-04 02:44:58 +00:00
|
|
|
|
2004-02-29 08:43:29 +00:00
|
|
|
$wgOut = new OutputPage();
|
|
|
|
|
wfDebug( "\n\n" );
|
|
|
|
|
|
2004-06-09 01:25:31 +00:00
|
|
|
wfProfileOut( $fname.'-OutputPage' );
|
|
|
|
|
wfProfileIn( $fname.'-DateFormatter' );
|
2004-06-04 02:44:58 +00:00
|
|
|
|
2003-11-21 02:43:12 +00:00
|
|
|
if ( $wgUseDynamicDates ) {
|
2004-06-09 01:25:31 +00:00
|
|
|
require_once( 'DateFormatter.php' );
|
2003-11-21 02:43:12 +00:00
|
|
|
global $wgDateFormatter;
|
|
|
|
|
$wgDateFormatter = new DateFormatter;
|
|
|
|
|
}
|
|
|
|
|
|
2004-06-09 01:25:31 +00:00
|
|
|
wfProfileOut( $fname.'-DateFormatter' );
|
|
|
|
|
wfProfileIn( $fname.'-SetupSession' );
|
2004-06-04 02:44:58 +00:00
|
|
|
|
2004-06-09 01:25:31 +00:00
|
|
|
if( !$wgCommandLineMode && ( isset( $_COOKIE[ini_get('session.name')] ) || isset( $_COOKIE[$wgDBname.'Password'] ) ) ) {
|
2004-01-30 17:07:50 +00:00
|
|
|
User::SetupSession();
|
2003-11-12 10:21:28 +00:00
|
|
|
}
|
|
|
|
|
|
2004-06-09 01:25:31 +00:00
|
|
|
wfProfileOut( $fname.'-SetupSession' );
|
|
|
|
|
wfProfileIn( $fname.'-BlockCache' );
|
2004-06-04 02:44:58 +00:00
|
|
|
|
2004-02-14 12:37:25 +00:00
|
|
|
$wgBlockCache = new BlockCache( true );
|
2004-06-04 02:44:58 +00:00
|
|
|
|
2004-06-09 01:25:31 +00:00
|
|
|
wfProfileOut( $fname.'-BlockCache' );
|
|
|
|
|
wfProfileIn( $fname.'-User' );
|
2004-06-04 02:44:58 +00:00
|
|
|
|
2004-05-02 09:06:56 +00:00
|
|
|
if( $wgCommandLineMode ) {
|
|
|
|
|
# Used for some maintenance scripts; user session cookies can screw things up
|
|
|
|
|
# when the database is in an in-between state.
|
|
|
|
|
$wgUser = new User();
|
|
|
|
|
} else {
|
|
|
|
|
$wgUser = User::loadFromSession();
|
|
|
|
|
}
|
2004-06-04 02:44:58 +00:00
|
|
|
|
2004-06-09 01:25:31 +00:00
|
|
|
wfProfileOut( $fname.'-User' );
|
|
|
|
|
wfProfileIn( $fname.'-misc' );
|
2004-06-04 02:44:58 +00:00
|
|
|
|
2003-04-14 23:10:40 +00:00
|
|
|
$wgDeferredUpdateList = array();
|
|
|
|
|
$wgLinkCache = new LinkCache();
|
2003-08-31 09:46:37 +00:00
|
|
|
$wgMagicWords = array();
|
|
|
|
|
$wgMwRedir =& MagicWord::get( MAG_REDIRECT );
|
2004-02-26 13:37:26 +00:00
|
|
|
$wgParserCache = new ParserCache();
|
|
|
|
|
$wgParser = new Parser();
|
2004-02-29 08:43:29 +00:00
|
|
|
$wgOut->setParserOptions( ParserOptions::newFromUser( $wgUser ) );
|
2004-06-15 15:00:54 +00:00
|
|
|
$wgDBConnections = array();
|
2003-10-25 08:01:33 +00:00
|
|
|
|
2004-05-31 08:43:36 +00:00
|
|
|
# Placeholders in case of DB error
|
2004-06-09 01:25:31 +00:00
|
|
|
$wgTitle = Title::newFromText( wfMsg( 'badtitle' ) );
|
2004-05-31 08:43:36 +00:00
|
|
|
$wgArticle = new Article($wgTitle);
|
|
|
|
|
|
2004-06-09 01:25:31 +00:00
|
|
|
wfProfileOut( $fname.'-misc' );
|
|
|
|
|
wfProfileIn( $fname.'-extensions' );
|
2004-06-04 02:44:58 +00:00
|
|
|
|
2004-05-15 03:36:39 +00:00
|
|
|
# Extension setup functions
|
|
|
|
|
# Entries should be added to this variable during the inclusion
|
|
|
|
|
# of the extension file. This allows the extension to perform
|
|
|
|
|
# any necessary initialisation in the fully initialised environment
|
|
|
|
|
foreach ( $wgExtensionFunctions as $func ) {
|
|
|
|
|
$func();
|
|
|
|
|
}
|
|
|
|
|
|
2004-06-09 01:25:31 +00:00
|
|
|
wfProfileOut( $fname.'-extensions' );
|
2003-10-25 08:01:33 +00:00
|
|
|
wfProfileOut( $fname );
|
|
|
|
|
|
2004-05-09 10:37:00 +00:00
|
|
|
|
2003-04-14 23:10:40 +00:00
|
|
|
?>
|