blob: d2dcbf92bbed3770af50c126c7533a4d4e52fa19 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
<?php
require_once 'counter.php';
/**
* Run all updaters.
*
* @todo document
* @package MediaWiki
* @subpackage Maintenance
*/
/** */
$wgUseMasterForMaintenance = true;
$options = array( 'quick' );
require_once( "commandLine.inc" );
require_once( "updaters.inc" );
$wgTitle = Title::newFromText( "MediaWiki database updater" );
$dbclass = 'Database' . ucfirst( $wgDBtype ) ;
echo( "MediaWiki {$wgVersion} Updater\n\n" );
# Do a pre-emptive check to ensure we've got credentials supplied
# We can't, at this stage, check them, but we can detect their absence,
# which seems to cause most of the problems people whinge about
if( !isset( $wgDBadminuser ) || !isset( $wgDBadminpassword ) ) {
echo( "No superuser credentials could be found. Please provide the details\n" );
echo( "of a user with appropriate permissions to update the database. See\n" );
echo( "AdminSettings.sample for more details.\n\n" );
exit();
}
# Attempt to connect to the database as a privileged user
# This will vomit up an error if there are permissions problems
$wgDatabase = new $dbclass( $wgDBserver, $wgDBadminuser, $wgDBadminpassword, $wgDBname, 1 );
if( !$wgDatabase->isOpen() ) {
# Appears to have failed
echo( "A connection to the database could not be established. Check the\n" );
echo( "values of \$wgDBadminuser and \$wgDBadminpassword.\n" );
exit();
}
print "Going to run database updates for ".wfWikiID()."\n";
print "Depending on the size of your database this may take a while!\n";
if( !isset( $options['quick'] ) ) {
print "Abort with control-c in the next five seconds... ";
for ($i = 6; $i >= 1;) {
print_c($i, --$i);
sleep(1);
}
echo "\n";
}
if ( isset( $options['doshared'] ) ) {
$doShared = true;
} else {
$doShared = false;
}
do_all_updates( $doShared );
print "Done.\n";
?>
|