X-Git-Url: http://git.heureux-cyclage.org/?a=blobdiff_plain;f=maintenance%2Faddwiki.php;h=5d71575a288fa833fba7dc27868fc2bfbefedd43;hb=44a950288a78c7cb89286271c068c2578865e0b3;hp=dfb9c9e817b5992c2e6a3c913ccd8a71e16e4733;hpb=e35eef9bb7edcbc4e266d6217f16b74a32c1eed4;p=lhc%2Fweb%2Fwiklou.git diff --git a/maintenance/addwiki.php b/maintenance/addwiki.php index dfb9c9e817..5d71575a28 100644 --- a/maintenance/addwiki.php +++ b/maintenance/addwiki.php @@ -1,103 +1,165 @@ \nThe site for Wikipedia is 'wikipedia'.\n" ); -} +class AddWiki extends Maintenance { + public function __construct() { + parent::__construct(); + $this->mDescription = "Add a new wiki to the family. Wikimedia specific!"; + $this->addArg( 'language', 'Language code of new site' ); + $this->addArg( 'site', 'Type of site' ); + $this->addArg( 'dbname', 'Name of database to create' ); + } -addWiki( $args[0], $args[1], $args[2] ); + public function getDbType() { + return Maintenance::DB_ADMIN; + } -# ----------------------------------------------------------------- + public function execute() { + global $IP, $wgDefaultExternalStore, $wgNoDBParam; -function addWiki( $lang, $site, $dbName ) -{ - global $IP, $wgLanguageNames, $wgDefaultExternalStore; + $wgNoDBParam = true; + $lang = $this->getArg( 0 ); + $site = $this->getArg( 1 ); + $dbName = $this->getArg( 2 ); + $languageNames = Language::getLanguageNames(); - if ( !isset( $wgLanguageNames[$lang] ) ) { - print "Language $lang not found in \$wgLanguageNames\n"; - return; - } - $name = $wgLanguageNames[$lang]; + if ( !isset( $languageNames[$lang] ) ) { + $this->error( "Language $lang not found in \$wgLanguageNames", true ); + } + $name = $languageNames[$lang]; - $dbw = wfGetDB( DB_MASTER ); - $common = "/home/wikipedia/common"; - $maintenance = "$IP/maintenance"; + $dbw = wfGetDB( DB_MASTER ); + $common = "/home/wikipedia/common"; - print "Creating database $dbName for $lang.$site ($name)\n"; - - # Set up the database - $dbw->query( "SET table_type=Innodb" ); - $dbw->query( "CREATE DATABASE $dbName" ); - $dbw->selectDB( $dbName ); - - print "Initialising tables\n"; - dbsource( "$maintenance/tables.sql", $dbw ); - dbsource( "$IP/extensions/OAI/update_table.sql", $dbw ); - dbsource( "$IP/extensions/AntiSpoof/mysql/patch-antispoof.sql", $dbw ); - dbsource( "$IP/extensions/CheckUser/cu_changes.sql", $dbw ); - dbsource( "$IP/extensions/CheckUser/cu_log.sql", $dbw ); - dbsource( "$IP/extensions/TitleKey/titlekey.sql", $dbw ); - dbsource( "$IP/extensions/Oversight/hidden.sql", $dbw ); - - $dbw->query( "INSERT INTO site_stats(ss_row_id) VALUES (1)" ); - - # Initialise external storage - if ( is_array( $wgDefaultExternalStore ) ) { - $stores = $wgDefaultExternalStore; - } elseif ( $stores ) { - $stores = array( $wgDefaultExternalStore ); - } else { - $stores = array(); - } - if ( count( $stores ) ) { - require_once( 'ExternalStoreDB.php' ); - print "Initialising external storage $store...\n"; - global $wgDBuser, $wgDBpassword, $wgExternalServers; - foreach ( $stores as $storeURL ) { - $m = array(); - if ( !preg_match( '!^DB://(.*)$!', $storeURL, $m ) ) { - continue; + $this->output( "Creating database $dbName for $lang.$site ($name)\n" ); + + # Set up the database + $dbw->query( "SET table_type=Innodb" ); + $dbw->query( "CREATE DATABASE $dbName" ); + $dbw->selectDB( $dbName ); + + $this->output( "Initialising tables\n" ); + $dbw->sourceFile( $this->getDir() . '/tables.sql' ); + $dbw->sourceFile( "$IP/extensions/OAI/update_table.sql" ); + $dbw->sourceFile( "$IP/extensions/AntiSpoof/sql/patch-antispoof.mysql.sql" ); + $dbw->sourceFile( "$IP/extensions/CheckUser/cu_changes.sql" ); + $dbw->sourceFile( "$IP/extensions/CheckUser/cu_log.sql" ); + $dbw->sourceFile( "$IP/extensions/TitleKey/titlekey.sql" ); + $dbw->sourceFile( "$IP/extensions/Oversight/hidden.sql" ); + $dbw->sourceFile( "$IP/extensions/GlobalBlocking/localdb_patches/setup-global_block_whitelist.sql" ); + $dbw->sourceFile( "$IP/extensions/AbuseFilter/abusefilter.tables.sql" ); + $dbw->sourceFile( "$IP/extensions/UsabilityInitiative/PrefStats/PrefStats.sql" ); + $dbw->sourceFile( "$IP/extensions/ProofreadPage/ProofreadPage.sql" ); + $dbw->sourceFile( "$IP/extensions/UsabilityInitiative/ClickTracking/ClickTrackingEvents.sql" ); + $dbw->sourceFile( "$IP/extensions/UsabilityInitiative/ClickTracking/ClickTracking.sql" ); + $dbw->sourceFile( "$IP/extensions/UsabilityInitiative/UserDailyContribs/UserDailyContribs.sql" ); + $dbw->sourceFile( "$IP/extensions/UsabilityInitiative/Optin/OptIn.sql" ); + + $dbw->query( "INSERT INTO site_stats(ss_row_id) VALUES (1)" ); + + # Initialise external storage + if ( is_array( $wgDefaultExternalStore ) ) { + $stores = $wgDefaultExternalStore; + } elseif ( $stores ) { + $stores = array( $wgDefaultExternalStore ); + } else { + $stores = array(); + } + if ( count( $stores ) ) { + global $wgDBuser, $wgDBpassword, $wgExternalServers; + foreach ( $stores as $storeURL ) { + $m = array(); + if ( !preg_match( '!^DB://(.*)$!', $storeURL, $m ) ) { + continue; + } + + $cluster = $m[1]; + $this->output( "Initialising external storage $cluster...\n" ); + + # Hack + $wgExternalServers[$cluster][0]['user'] = $wgDBuser; + $wgExternalServers[$cluster][0]['password'] = $wgDBpassword; + + $store = new ExternalStoreDB; + $extdb = $store->getMaster( $cluster ); + $extdb->query( "SET table_type=InnoDB" ); + $extdb->query( "CREATE DATABASE $dbName" ); + $extdb->selectDB( $dbName ); + + # Hack x2 + $blobsTable = $store->getTable( $extdb ); + $sedCmd = "sed s/blobs\\\\\\>/$blobsTable/ " . $this->getDir() . "/storage/blobs.sql"; + $blobsFile = popen( $sedCmd, 'r' ); + $extdb->sourceStream( $blobsFile ); + pclose( $blobsFile ); + $extdb->commit(); } - - $cluster = $m[1]; - - # Hack - $wgExternalServers[$cluster][0]['user'] = $wgDBuser; - $wgExternalServers[$cluster][0]['password'] = $wgDBpassword; - - $store = new ExternalStoreDB; - $extdb =& $store->getMaster( $cluster ); - $extdb->query( "SET table_type=InnoDB" ); - $extdb->query( "CREATE DATABASE $dbName" ); - $extdb->selectDB( $dbName ); - dbsource( "$maintenance/storage/blobs.sql", $extdb ); - $extdb->immediateCommit(); } - } - global $wgTitle, $wgArticle; - $wgTitle = Title::newFromText( wfMsgWeirdKey( "mainpage/$lang" ) ); - print "Writing main page to " . $wgTitle->getPrefixedDBkey() . "\n"; - $wgArticle = new Article( $wgTitle ); - $ucsite = ucfirst( $site ); + global $wgTitle, $wgArticle; + $wgTitle = Title::newFromText( wfMsgWeirdKey( "mainpage/$lang" ) ); + $this->output( "Writing main page to " . $wgTitle->getPrefixedDBkey() . "\n" ); + $wgArticle = new Article( $wgTitle ); + $ucsite = ucfirst( $site ); + + $wgArticle->insertNewArticle( $this->getFirstArticle( $ucsite, $name ), '', false, false ); + + $this->output( "Adding to dblists\n" ); + + # Add to dblist + $file = fopen( "$common/all.dblist", "a" ); + fwrite( $file, "$dbName\n" ); + fclose( $file ); + + # Update the sublists + shell_exec( "cd $common && ./refresh-dblist" ); + + # print "Constructing interwiki SQL\n"; + # Rebuild interwiki tables + # passthru( '/home/wikipedia/conf/interwiki/update' ); - $wgArticle->insertNewArticle( <<output( "Script ended. You still have to: + * Add any required settings in InitialiseSettings.php + * Run sync-common-all + * Run /home/wikipedia/conf/interwiki/update + " ); + } + + private function getFirstArticle( $ucsite, $name ) { + return <<