* (bug 21503) There's now a "reason" field when creating account for other users
[lhc/web/wiklou.git] / maintenance / addwiki.php
1 <?php
2 /**
3 * @defgroup Wikimedia Wikimedia
4 */
5
6 /**
7 * Add a new wiki
8 * Wikimedia specific!
9 *
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License along
21 * with this program; if not, write to the Free Software Foundation, Inc.,
22 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
23 * http://www.gnu.org/copyleft/gpl.html
24 *
25 * @file
26 * @ingroup Maintenance
27 * @ingroup Wikimedia
28 */
29
30 require_once( dirname( __FILE__ ) . '/Maintenance.php' );
31
32 class AddWiki extends Maintenance {
33 public function __construct() {
34 parent::__construct();
35 $this->mDescription = "Add a new wiki to the family. Wikimedia specific!";
36 $this->addArg( 'language', 'Language code of new site, e.g. en' );
37 $this->addArg( 'site', 'Type of site, e.g. wikipedia' );
38 $this->addArg( 'dbname', 'Name of database to create, e.g. enwiki' );
39 $this->addArg( 'domain', 'Domain name of the wiki, e.g. en.wikipedia.org' );
40 }
41
42 public function getDbType() {
43 return Maintenance::DB_ADMIN;
44 }
45
46 public function execute() {
47 global $IP, $wgDefaultExternalStore, $wgNoDBParam;
48
49 $wgNoDBParam = true;
50 $lang = $this->getArg( 0 );
51 $site = $this->getArg( 1 );
52 $dbName = $this->getArg( 2 );
53 $domain = $this->getArg( 3 );
54 $languageNames = Language::getLanguageNames();
55
56 if ( !isset( $languageNames[$lang] ) ) {
57 $this->error( "Language $lang not found in \$wgLanguageNames", true );
58 }
59 $name = $languageNames[$lang];
60
61 $dbw = wfGetDB( DB_MASTER );
62 $common = "/home/wikipedia/common";
63
64 $this->output( "Creating database $dbName for $lang.$site ($name)\n" );
65
66 # Set up the database
67 $dbw->query( "SET table_type=Innodb" );
68 $dbw->query( "CREATE DATABASE $dbName" );
69 $dbw->selectDB( $dbName );
70
71 $this->output( "Initialising tables\n" );
72 $dbw->sourceFile( $this->getDir() . '/tables.sql' );
73 $dbw->sourceFile( "$IP/extensions/OAI/update_table.sql" );
74 $dbw->sourceFile( "$IP/extensions/AntiSpoof/sql/patch-antispoof.mysql.sql" );
75 $dbw->sourceFile( "$IP/extensions/CheckUser/cu_changes.sql" );
76 $dbw->sourceFile( "$IP/extensions/CheckUser/cu_log.sql" );
77 $dbw->sourceFile( "$IP/extensions/TitleKey/titlekey.sql" );
78 $dbw->sourceFile( "$IP/extensions/Oversight/hidden.sql" );
79 $dbw->sourceFile( "$IP/extensions/GlobalBlocking/localdb_patches/setup-global_block_whitelist.sql" );
80 $dbw->sourceFile( "$IP/extensions/AbuseFilter/abusefilter.tables.sql" );
81 $dbw->sourceFile( "$IP/extensions/UsabilityInitiative/PrefStats/PrefStats.sql" );
82 $dbw->sourceFile( "$IP/extensions/ProofreadPage/ProofreadPage.sql" );
83 $dbw->sourceFile( "$IP/extensions/UsabilityInitiative/ClickTracking/ClickTrackingEvents.sql" );
84 $dbw->sourceFile( "$IP/extensions/UsabilityInitiative/ClickTracking/ClickTracking.sql" );
85 $dbw->sourceFile( "$IP/extensions/UsabilityInitiative/UserDailyContribs/UserDailyContribs.sql" );
86 $dbw->sourceFile( "$IP/extensions/UsabilityInitiative/OptIn/OptIn.sql" );
87
88 $dbw->query( "INSERT INTO site_stats(ss_row_id) VALUES (1)" );
89
90 # Initialise external storage
91 if ( is_array( $wgDefaultExternalStore ) ) {
92 $stores = $wgDefaultExternalStore;
93 } elseif ( $stores ) {
94 $stores = array( $wgDefaultExternalStore );
95 } else {
96 $stores = array();
97 }
98 if ( count( $stores ) ) {
99 global $wgDBuser, $wgDBpassword, $wgExternalServers;
100 foreach ( $stores as $storeURL ) {
101 $m = array();
102 if ( !preg_match( '!^DB://(.*)$!', $storeURL, $m ) ) {
103 continue;
104 }
105
106 $cluster = $m[1];
107 $this->output( "Initialising external storage $cluster...\n" );
108
109 # Hack
110 $wgExternalServers[$cluster][0]['user'] = $wgDBuser;
111 $wgExternalServers[$cluster][0]['password'] = $wgDBpassword;
112
113 $store = new ExternalStoreDB;
114 $extdb = $store->getMaster( $cluster );
115 $extdb->query( "SET table_type=InnoDB" );
116 $extdb->query( "CREATE DATABASE $dbName" );
117 $extdb->selectDB( $dbName );
118
119 # Hack x2
120 $blobsTable = $store->getTable( $extdb );
121 $sedCmd = "sed s/blobs\\\\\\>/$blobsTable/ " . $this->getDir() . "/storage/blobs.sql";
122 $blobsFile = popen( $sedCmd, 'r' );
123 $extdb->sourceStream( $blobsFile );
124 pclose( $blobsFile );
125 $extdb->commit();
126 }
127 }
128
129 global $wgTitle, $wgArticle;
130 $wgTitle = Title::newFromText( wfMsgWeirdKey( "mainpage/$lang" ) );
131 $this->output( "Writing main page to " . $wgTitle->getPrefixedDBkey() . "\n" );
132 $wgArticle = new Article( $wgTitle );
133 $ucsite = ucfirst( $site );
134
135 $wgArticle->doEdit( $this->getFirstArticle( $ucsite, $name ), '', EDIT_NEW | EDIT_DEFER_UPDATES | EDIT_AUTOSUMMARY,
136 false, null, false, false, '', true );
137
138 $this->output( "Adding to dblists\n" );
139
140 # Add to dblist
141 $file = fopen( "$common/all.dblist", "a" );
142 fwrite( $file, "$dbName\n" );
143 fclose( $file );
144
145 # Update the sublists
146 shell_exec( "cd $common && ./refresh-dblist" );
147
148 # print "Constructing interwiki SQL\n";
149 # Rebuild interwiki tables
150 # passthru( '/home/wikipedia/conf/interwiki/update' );
151
152 $time = wfTimestamp( TS_RFC2822 );
153 // These arguments need to be escaped twice: once for echo and once for at
154 $escDbName = wfEscapeShellArg( wfEscapeShellArg( $dbName ) );
155 $escTime = wfEscapeShellArg( wfEscapeShellArg( $time ) );
156 $escUcsite = wfEscapeShellArg( wfEscapeShellArg( $ucsite ) );
157 $escName = wfEscapeShellArg( wfEscapeShellArg( $name ) );
158 $escLang = wfEscapeShellArg( wfEscapeShellArg( $lang ) );
159 $escDomain = wfEscapeShellArg( wfEscapeShellArg( $domain ) );
160 shell_exec( "echo notifyNewProjects $escDbName $escTime $escUcsite $escName $escLang $escDomain | at now + 15 minutes" );
161
162 $this->output( "Script ended. You still have to:
163 * Add any required settings in InitialiseSettings.php
164 * Run sync-common-all
165 * Run /home/wikipedia/conf/interwiki/update
166 " );
167 }
168
169 private function getFirstArticle( $ucsite, $name ) {
170 return <<<EOT
171 ==This subdomain is reserved for the creation of a [[wikimedia:Our projects|$ucsite]] in '''[[w:en:{$name}|{$name}]]''' language==
172
173 * Please '''do not start editing''' this new site. This site has a test project on the [[incubator:|Wikimedia Incubator]] (or on the [[betawikiversity:|BetaWikiversity]] or on the [[oldwikisource:|Old Wikisource]]) and it will be imported to here.
174
175 * If you would like to help translating the interface to this language, please do not translate here, but go to [[translatewiki:|translatewiki]], a special wiki for translating the interface. That way everyone can use it on every wiki using the [[mw:|same software]].
176
177 * For information about how to edit and for other general help, see [[m:Help:Contents|Help on Wikimedia's Meta-Wiki]] or [[mw:Help:Contents|Help on MediaWiki.org]].
178
179 == Sister projects ==
180 <span class="plainlinks">
181 [http://www.wikipedia.org Wikipedia] |
182 [http://www.wiktionary.org Wiktonary] |
183 [http://www.wikibooks.org Wikibooks] |
184 [http://www.wikinews.org Wikinews] |
185 [http://www.wikiquote.org Wikiquote] |
186 [http://www.wikisource.org Wikisource]
187 [http://www.wikiversity.org Wikiversity]
188 </span>
189
190 See Wikimedia's [[m:|Meta-Wiki]] for the coordination of these projects.
191
192 [[aa:]]
193 [[ab:]]
194 [[ace:]]
195 [[af:]]
196 [[ak:]]
197 [[als:]]
198 [[am:]]
199 [[an:]]
200 [[ang:]]
201 [[ar:]]
202 [[arc:]]
203 [[arz:]]
204 [[as:]]
205 [[ast:]]
206 [[av:]]
207 [[ay:]]
208 [[az:]]
209 [[ba:]]
210 [[bar:]]
211 [[bat-smg:]]
212 [[bcl:]]
213 [[be:]]
214 [[be-x-old:]]
215 [[bg:]]
216 [[bh:]]
217 [[bi:]]
218 [[bm:]]
219 [[bn:]]
220 [[bo:]]
221 [[bpy:]]
222 [[br:]]
223 [[bs:]]
224 [[bug:]]
225 [[bxr:]]
226 [[ca:]]
227 [[cbk-zam:]]
228 [[cdo:]]
229 [[ce:]]
230 [[ceb:]]
231 [[ch:]]
232 [[cho:]]
233 [[chr:]]
234 [[chy:]]
235 [[ckb:]]
236 [[co:]]
237 [[cr:]]
238 [[crh:]]
239 [[cs:]]
240 [[csb:]]
241 [[cu:]]
242 [[cv:]]
243 [[cy:]]
244 [[da:]]
245 [[de:]]
246 [[diq:]]
247 [[dk:]]
248 [[dsb:]]
249 [[dv:]]
250 [[dz:]]
251 [[ee:]]
252 [[el:]]
253 [[eml:]]
254 [[en:]]
255 [[eo:]]
256 [[es:]]
257 [[et:]]
258 [[eu:]]
259 [[ext:]]
260 [[fa:]]
261 [[ff:]]
262 [[fi:]]
263 [[fiu-vro:]]
264 [[fj:]]
265 [[fo:]]
266 [[fr:]]
267 [[frp:]]
268 [[fur:]]
269 [[fy:]]
270 [[ga:]]
271 [[gan:]]
272 [[gd:]]
273 [[gl:]]
274 [[glk:]]
275 [[gn:]]
276 [[got:]]
277 [[gu:]]
278 [[gv:]]
279 [[ha:]]
280 [[hak:]]
281 [[haw:]]
282 [[he:]]
283 [[hi:]]
284 [[hif:]]
285 [[ho:]]
286 [[hr:]]
287 [[hsb:]]
288 [[ht:]]
289 [[hu:]]
290 [[hy:]]
291 [[hz:]]
292 [[ia:]]
293 [[id:]]
294 [[ie:]]
295 [[ig:]]
296 [[ii:]]
297 [[ik:]]
298 [[ilo:]]
299 [[io:]]
300 [[is:]]
301 [[it:]]
302 [[iu:]]
303 [[ja:]]
304 [[jbo:]]
305 [[jv:]]
306 [[ka:]]
307 [[kaa:]]
308 [[kab:]]
309 [[kg:]]
310 [[ki:]]
311 [[kj:]]
312 [[kk:]]
313 [[kl:]]
314 [[km:]]
315 [[kn:]]
316 [[ko:]]
317 [[kr:]]
318 [[ks:]]
319 [[ksh:]]
320 [[ku:]]
321 [[kv:]]
322 [[kw:]]
323 [[ky:]]
324 [[la:]]
325 [[lad:]]
326 [[lb:]]
327 [[lbe:]]
328 [[lg:]]
329 [[li:]]
330 [[lij:]]
331 [[lmo:]]
332 [[ln:]]
333 [[lo:]]
334 [[lt:]]
335 [[lv:]]
336 [[map-bms:]]
337 [[mdf:]]
338 [[mg:]]
339 [[mh:]]
340 [[mhr:]]
341 [[mi:]]
342 [[mk:]]
343 [[ml:]]
344 [[mn:]]
345 [[mo:]]
346 [[mr:]]
347 [[ms:]]
348 [[mt:]]
349 [[mus:]]
350 [[mwl:]]
351 [[my:]]
352 [[myv:]]
353 [[mzn:]]
354 [[na:]]
355 [[nan:]]
356 [[nap:]]
357 [[nds:]]
358 [[nds-nl:]]
359 [[ne:]]
360 [[new:]]
361 [[ng:]]
362 [[nl:]]
363 [[nn:]]
364 [[no:]]
365 [[nov:]]
366 [[nrm:]]
367 [[nv:]]
368 [[ny:]]
369 [[oc:]]
370 [[om:]]
371 [[or:]]
372 [[os:]]
373 [[pa:]]
374 [[pag:]]
375 [[pam:]]
376 [[pap:]]
377 [[pdc:]]
378 [[pi:]]
379 [[pih:]]
380 [[pl:]]
381 [[pms:]]
382 [[pnt:]]
383 [[pnb:]]
384 [[ps:]]
385 [[pt:]]
386 [[qu:]]
387 [[rm:]]
388 [[rmy:]]
389 [[rn:]]
390 [[ro:]]
391 [[roa-rup:]]
392 [[roa-tara:]]
393 [[ru:]]
394 [[rw:]]
395 [[sa:]]
396 [[sah:]]
397 [[sc:]]
398 [[scn:]]
399 [[sco:]]
400 [[sd:]]
401 [[se:]]
402 [[sg:]]
403 [[sh:]]
404 [[si:]]
405 [[simple:]]
406 [[sk:]]
407 [[sl:]]
408 [[sm:]]
409 [[sn:]]
410 [[so:]]
411 [[sq:]]
412 [[sr:]]
413 [[srn:]]
414 [[ss:]]
415 [[st:]]
416 [[stq:]]
417 [[su:]]
418 [[sv:]]
419 [[sw:]]
420 [[szl:]]
421 [[ta:]]
422 [[te:]]
423 [[tet:]]
424 [[tg:]]
425 [[th:]]
426 [[ti:]]
427 [[tk:]]
428 [[tl:]]
429 [[tn:]]
430 [[to:]]
431 [[tpi:]]
432 [[tr:]]
433 [[ts:]]
434 [[tt:]]
435 [[tum:]]
436 [[tw:]]
437 [[ty:]]
438 [[udm:]]
439 [[ug:]]
440 [[uk:]]
441 [[ur:]]
442 [[uz:]]
443 [[ve:]]
444 [[vec:]]
445 [[vi:]]
446 [[vls:]]
447 [[vo:]]
448 [[wa:]]
449 [[war:]]
450 [[wo:]]
451 [[wuu:]]
452 [[xal:]]
453 [[xh:]]
454 [[yi:]]
455 [[yo:]]
456 [[za:]]
457 [[zea:]]
458 [[zh:]]
459 [[zh-classical:]]
460 [[zh-min-nan:]]
461 [[zh-yue:]]
462 [[zu:]]
463
464 EOT;
465 }
466 }
467
468 $maintClass = "AddWiki";
469 require_once( DO_MAINTENANCE );