<?php
/**
- * Main wiki script; see docs/design.doc
+ * Main wiki script; see docs/design.txt
* @package MediaWiki
*/
-
$wgRequestTime = microtime();
unset( $IP );
@ini_set( 'allow_url_fopen', 0 ); # For security...
+if ( isset( $_REQUEST['GLOBALS'] ) ) {
+ die( '<a href="http://www.hardened-php.net/index.76.html">$GLOBALS overwrite vulnerability</a>');
+}
+
# Valid web server entry point, enable includes.
# Please don't move this line to includes/Defines.php. This line essentially defines
# a valid entry point. If you put it in includes/Defines.php, then any script that includes
$IP = "." ;
require_once( 'includes/DefaultSettings.php' ); # used for printing the version
?>
-<!DOCTYPE html PUBLIC "-//W3C/DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns='http://www.w3.org/1999/xhtml' xml:lang='en' lang='en'>
<head>
<title>MediaWiki <?php echo $wgVersion ?></title>
<meta http-equiv='Content-Type' content='text/html; charset=utf-8' />
-
<style type='text/css' media='screen, projection'>
html, body {
color: #000;
background-color: #fff;
- font-family: serif;
- text-align:center;
+ font-family: sans-serif;
+ text-align: center;
}
h1 {
</style>
</head>
<body>
- <img src='skins/common/images/wiki.png' alt='The MediaWiki logo' />
-
+ <img src='skins/common/images/mediawiki.png' alt='The MediaWiki logo' />
+
<h1>MediaWiki <?php echo $wgVersion ?></h1>
<div class='error'>
<?php
if ( file_exists( 'config/LocalSettings.php' ) ) {
echo( "To complete the installation, move <tt>config/LocalSettings.php</tt> to the parent directory." );
} else {
- echo( "You'll have to <a href='config/index.php' title='setup'>set the wiki up</a> first!" );
+ echo( "Please <a href='config/index.php' title='setup'>setup the wiki</a> first." );
}
?>
$action = $wgRequest->getVal( 'action', 'view' );
$title = $wgRequest->getVal( 'title' );
-$action = strtolower( trim( $action ) );
if ($wgRequest->getVal( 'printable' ) == 'yes') {
$wgOut->setPrintable();
}
$wgTitle = Title::newFromID( $curid );
} else {
$wgTitle = Title::newFromURL( $title );
+ /* check variant links so that interwiki links don't have to worry about
+ the possible different language variants
+ */
+ if( count($wgContLang->getVariants()) > 1 && !is_null($wgTitle) && $wgTitle->getArticleID() == 0 )
+ $wgContLang->findVariantLink( $title, $wgTitle );
+
}
wfProfileOut( 'main-misc-setup' );
# Debug statement for user levels
// print_r($wgUser);
+$search = $wgRequest->getText( 'search' );
+if( !is_null( $search ) && $search !== '' ) {
+ // Compatibility with old search URLs which didn't use Special:Search
+ // Do this above the read whitelist check for security...
+ $wgTitle = Title::makeTitle( NS_SPECIAL, 'Search' );
+}
+
# If the user is not logged in, the Namespace:title of the article must be in
# the Read array in order for the user to see it. (We have to check here to
# catch special pages etc. We check again in Article::view())
wfProfileIn( 'main-action' );
-$search = $wgRequest->getText( 'search' );
if( !$wgDisableInternalSearch && !is_null( $search ) && $search !== '' ) {
require_once( 'includes/SpecialSearch.php' );
$wgTitle = Title::makeTitle( NS_SPECIAL, 'Search' );
$wgOut->redirect( $wgTitle->getFullURL(), '301');
} else if ( NS_SPECIAL == $wgTitle->getNamespace() ) {
# actions that need to be made when we have a special pages
- require_once( 'includes/SpecialPage.php' );
SpecialPage::executePath( $wgTitle );
} else {
if ( NS_MEDIA == $wgTitle->getNamespace() ) {
$wgTitle = Title::makeTitle( NS_IMAGE, $wgTitle->getDBkey() );
}
- switch( $wgTitle->getNamespace() ) {
- case NS_IMAGE:
+ $ns = $wgTitle->getNamespace();
+
+ // Namespace might change when using redirects
+ if($action == 'view' && !$wgRequest->getVal( 'oldid' ) ) {
+ $wgArticle = new Article( $wgTitle );
+ $rTitle = Title::newFromRedirect( $wgArticle->fetchContent() );
+ if($rTitle) {
+ # Reload from the page pointed to later
+ $wgArticle->mContentLoaded = false;
+ $ns = $rTitle->getNamespace();
+ }
+ }
+
+ // Categories and images are handled by a different class
+ if ( $ns == NS_IMAGE ) {
+ unset($wgArticle);
require_once( 'includes/ImagePage.php' );
$wgArticle = new ImagePage( $wgTitle );
- break;
- case NS_CATEGORY:
- if ( $wgUseCategoryMagic ) {
- require_once( 'includes/CategoryPage.php' );
- $wgArticle = new CategoryPage( $wgTitle );
- break;
- }
- # NO break if wgUseCategoryMagic is false, drop through to next (default).
- # Don't insert other cases between NS_CATEGORY and default.
- default:
- $wgArticle = new Article( $wgTitle );
+ } elseif ( $wgUseCategoryMagic && $ns == NS_CATEGORY ) {
+ unset($wgArticle);
+ require_once( 'includes/CategoryPage.php' );
+ $wgArticle = new CategoryPage( $wgTitle );
}
if ( in_array( $action, $wgDisabledActions ) ) {
case 'info':
case 'markpatrolled':
case 'validate':
+ case 'render':
+ case 'deletetrackback':
+ case 'purge':
$wgArticle->$action();
break;
case 'print':
User::SetupSession();
}
# Continue...
- case 'edit':
+ case 'edit':
$internal = $wgRequest->getVal( 'internaledit' );
$external = $wgRequest->getVal( 'externaledit' );
$section = $wgRequest->getVal( 'section' );
- $oldid = $wgRequest->getVal( 'oldid' );
- if(!$wgUseExternalEditor || $action=='submit' || $internal ||
+ $oldid = $wgRequest->getVal( 'oldid' );
+ if(!$wgUseExternalEditor || $action=='submit' || $internal ||
$section || $oldid || (!$wgUser->getOption('externaleditor') && !$external)) {
require_once( 'includes/EditPage.php' );
$editor = new EditPage( $wgArticle );
- $editor->submit();
+ $editor->submit();
} elseif($wgUseExternalEditor && ($external || $wgUser->getOption('externaleditor'))) {
require_once( 'includes/ExternalEdit.php' );
$mode = $wgRequest->getVal( 'mode' );
- $extedit = new ExternalEdit( $wgArticle, $mode );
+ $extedit = new ExternalEdit( $wgArticle, $mode );
$extedit->edit();
}
break;
$raw = new RawPage( $wgArticle );
$raw->view();
break;
- case 'purge':
- wfPurgeSquidServers(array($wgTitle->getInternalURL()));
- $wgOut->setSquidMaxage( $wgSquidMaxage );
- $wgTitle->invalidateCache();
- $wgArticle->view();
- break;
default:
- if (wfRunHooks('UnknownAction', $action, $wgArticle)) {
+ if (wfRunHooks('UnknownAction', array($action, $wgArticle))) {
$wgOut->errorpage( 'nosuchaction', 'nosuchactiontext' );
}
}