-<?
+<?php
+
+die("obsolete; remove this file befor 1.3.0 release\n");
# Update already-installed software
#
+include( "./install-utils.inc" );
+require_once( "./maintenance/updaters.inc" );
+install_version_checks();
+
if ( ! ( is_readable( "./LocalSettings.php" )
&& is_readable( "./AdminSettings.php" ) ) ) {
print "A copy of your installation's LocalSettings.php\n" .
exit();
}
-$DP = "./includes";
-include_once( "./LocalSettings.php" );
-include_once( "./AdminSettings.php" );
+$IP = "./includes";
+require_once( "./LocalSettings.php" );
+require_once( "./AdminSettings.php" );
+
+include( "$IP/Version.php" );
+
+if( $wgSitename == "MediaWiki" ) {
+ die( "You must set the site name in \$wgSitename before installation.\n\n" );
+}
if ( $wgUseTeX && ( ! is_executable( "./math/texvc" ) ) ) {
print "To use math functions, you must first compile texvc by\n" .
exit();
}
-umask( 000 );
-set_time_limit( 0 );
-
-include_once( "{$IP}/Version.php" );
-include_once( "{$IP}/Setup.php" );
-$wgTitle = Title::newFromText( "Update script" );
-$wgCommandLineMode = true;
-
-do_revision_updates();
-
#
# Copy files into installation directories
#
-print "Copying files...\n";
+do_update_files();
-copyfile( ".", "wiki.phtml", $IP );
-copyfile( ".", "redirect.phtml", $IP );
-copyfile( ".", "texvc.phtml", $IP );
+$wgDBuser = $wgDBadminuser;
+$wgDBpassword = $wgDBadminpassword;
-copydirectory( "./includes", $IP );
-copydirectory( "./stylesheets", $wgStyleSheetDirectory );
+require_once( "{$IP}/Setup.php" );
+require_once( "./maintenance/InitialiseMessages.inc" );
-copyfile( "./images", "wiki.png", $wgUploadDirectory );
-copyfile( "./languages", "Language.php", $IP );
-copyfile( "./languages", "Language" . ucfirst( $wgLanguageCode ) . ".php", $IP );
+$wgTitle = Title::newFromText( "Update script" );
-$fp = fopen( $wgDebugLogFile, "w" );
-if ( false === $fp ) {
- print "Could not create log file \"{$wgDebugLogFile}\".\n";
+#
+# Check the database for things that need to be fixed...
+#
+print "Checking database for necessary updates...\n";
+
+$wgDatabase = Database::newFromParams( $wgDBserver, $wgDBadminuser, $wgDBadminpassword, $wgDBname,
+ 1, false, true, false);
+if ( !$wgDatabase->isOpen() ) {
+ print "Unable to connect to database: " . $wgDatabase->lastError() . "\n";
exit();
}
-$d = date( "Y-m-d H:i:s" );
-fwrite( $fp, "Wiki debug log file created {$d}\n\n" );
-fclose( $fp );
-
-if ( $wgUseTeX ) {
- copyfile( "./math", "texvc", "{$IP}/math", 0775 );
- copyfile( "./math", "texvc_test", "{$IP}/math", 0775 );
- copyfile( "./math", "texvc_tex", "{$IP}/math", 0775 );
-}
-copyfile( ".", "Version.php", $IP );
+do_revision_updates();
+
+do_ipblocks_update();
+do_interwiki_update();
+do_index_update();
+do_linkscc_update();
+do_hitcounter_update();
+do_recentchanges_update();
+do_user_real_name_update();
+
+initialiseMessages();
+
+$wgDatabase->close();
print "Done.\n";
exit();
#
#
-function copyfile( $sdir, $name, $ddir, $perms = 0664 ) {
- global $wgInstallOwner, $wgInstallGroup;
-
- $d = "{$ddir}/{$name}";
- if ( copy( "{$sdir}/{$name}", $d ) ) {
- if ( isset( $wgInstallOwner ) ) { chown( $d, $wgInstallOwner ); }
- if ( isset( $wgInstallGroup ) ) { chgrp( $d, $wgInstallGroup ); }
- chmod( $d, $perms );
- # print "Copied \"{$name}\" to \"{$ddir}\".\n";
- } else {
- print "Failed to copy file \"{$name}\" to \"{$ddir}\".\n";
- exit();
+function do_update_files() {
+ global $IP, $wgStyleSheetDirectory, $wgUploadDirectory, $wgLanguageCode, $wgDebugLogFile;
+ print "Copying files... ";
+
+ copyfile( ".", "LocalSettings.php", $IP );
+ copyfile( ".", "index.php", $IP );
+ copyfile( ".", "redirect.php", $IP );
+ # compatibility with older versions, can be removed in a year or so
+ # (written in Feb 2004)
+ copyfile( ".", "wiki.phtml", $IP );
+ copyfile( ".", "redirect.phtml", $IP );
+
+ copydirectory( "./includes", $IP );
+ copydirectory( "./stylesheets", $wgStyleSheetDirectory );
+
+ copyfile( "./images", "wiki.png", $wgUploadDirectory );
+ copyfile( "./images", "button_bold.png", $wgUploadDirectory );
+ copyfile( "./images", "button_extlink.png", $wgUploadDirectory );
+ copyfile( "./images", "button_headline.png", $wgUploadDirectory );
+ copyfile( "./images", "button_hr.png", $wgUploadDirectory );
+ copyfile( "./images", "button_image.png", $wgUploadDirectory );
+ copyfile( "./images", "button_italic.png", $wgUploadDirectory );
+ copyfile( "./images", "button_link.png", $wgUploadDirectory );
+ copyfile( "./images", "button_math.png", $wgUploadDirectory );
+ copyfile( "./images", "button_media.png", $wgUploadDirectory );
+ copyfile( "./images", "button_nowiki.png", $wgUploadDirectory );
+ copyfile( "./images", "button_sig.png", $wgUploadDirectory );
+ copyfile( "./images", "button_template.png", $wgUploadDirectory );
+ copyfile( "./images", "magnify-clip.png", $wgUploadDirectory );
+ copyfile( "./images", "Arr_.png", $wgUploadDirectory );
+ copyfile( "./images", "Arr_r.png", $wgUploadDirectory );
+ copyfile( "./images", "Arr_d.png", $wgUploadDirectory );
+ copyfile( "./images", "Arr_l.png", $wgUploadDirectory );
+
+ copyfile( "./languages", "Language.php", $IP );
+ copyfile( "./languages", "LanguageUtf8.php", $IP );
+ copyfile( "./languages", "Language" . ucfirst( $wgLanguageCode ) . ".php", $IP );
+
+ if( !empty( $wgDebugLogFile ) ) {
+ $fp = fopen( $wgDebugLogFile, "w" );
+ if ( false === $fp ) {
+ print "Could not create log file \"{$wgDebugLogFile}\".\n";
+ exit();
+ }
+ $d = date( "Y-m-d H:i:s" );
+ fwrite( $fp, "Wiki debug log file created {$d}\n\n" );
+ fclose( $fp );
}
-}
-
-function copydirectory( $source, $dest ) {
- $handle = opendir( $source );
- while ( false !== ( $f = readdir( $handle ) ) ) {
- if ( "." == $f{0} ) continue;
- if ( "CVS" == $f ) continue;
- copyfile( $source, $f, $dest );
+
+ if ( $wgUseTeX ) {
+ copyfile( "./math", "texvc", "{$IP}/math", 0775 );
+ copyfile( "./math", "texvc_test", "{$IP}/math", 0775 );
+ copyfile( "./math", "texvc_tex", "{$IP}/math", 0775 );
}
-}
+
+ copyfile( ".", "Version.php", $IP );
-function do_revision_updates() {
- global $wgSoftwareRevision;
-
- if ( $wgSoftwareRevision < 1001 ) { update_passwords(); }
-}
-
-function update_passwords() {
- $fname = "Update scripte: update_passwords()";
- print "Updating passwords...\n";
-
- $sql = "SELECT user_id,user_password FROM user";
- $source = wfQuery( $sql, fname );
-
- while ( $row = mysql_fetch_object( $source ) ) {
- $id = $row->user_id;
- $oldpass = $row->user_password;
- $newpass = md5( $oldpass . $id );
-
- $sql = "UPDATE user SET user_password='{$newpass}' " .
- "WHERE user_id={$id}";
- wfQuery( $sql, $fname );
- }
+ print "ok\n";
}
?>