24917f03d876582365b38b4dd1719e00a95cdce0
[lhc/web/wiklou.git] / maintenance / InitialiseMessages.inc
1 <?php
2
3 # This script is included from update.php and install.php. Do not run it
4 # by itself.
5
6 function initialiseMessages( $overwrite = false) {
7 global $wgLang, $wgScript, $wgServer, $wgAllMessagesEn;
8 global $wgOut, $wgArticle, $wgUser;
9 global $wgMessageCache, $wgMemc, $wgDBname, $wgDatabaseMessages;
10 $wgMessageCache->disable();
11
12 $fname = "initialiseMessages";
13 $ns = NS_MEDIAWIKI;
14
15 $timestamp = wfTimestampNow();
16 $invTimestamp = wfInvertTimestamp( $timestamp );
17 $mwMsg =& MagicWord::get( MAG_MSG );
18 $navText = str_replace( "$1", "allmessagestext", $mwMsg->getSynonym( 0 ) );
19 $navText .= "
20
21 <table border=1 width=100%><tr><td>
22 '''Name'''
23 </td><td>
24 '''Default text'''
25 </td><td>
26 '''Current text'''
27 </td></tr>";
28
29 print "Initialising \"MediaWiki\" namespace...\n";
30 $sql = "SELECT cur_title FROM cur WHERE cur_namespace=$ns AND cur_title IN(";
31
32 $first = true;
33 $sortedArray = $wgAllMessagesEn;
34 ksort( $sortedArray );
35
36 foreach ( $sortedArray as $key => $enMsg ) {
37 if ( $first ) {
38 $first = false;
39 } else {
40 $sql .= ",";
41 }
42
43 $message = wfMsgNoDB( $key );
44 $titleObj = Title::newFromText( $key );
45 $enctitle = wfStrencode($titleObj->getDBkey());
46 $sql .= "'$enctitle'";
47 }
48 $sql .= ")";
49 $res = wfQuery( $sql, DB_READ );
50 $row = wfFetchObject( $res );
51
52 $exists = array();
53 while ( $row ) {
54 $exists[$row->cur_title] = 1;
55 $row = wfFetchObject( $res );
56 }
57 $sql = "INSERT INTO cur (cur_namespace, cur_title, cur_text,
58 cur_user_text, cur_timestamp, cur_restrictions,
59 cur_is_new, inverse_timestamp, cur_touched) VALUES ";
60 $first = true;
61 $mwObj =& MagicWord::get( MAG_MSGNW );
62 $msgnw = $mwObj->getSynonym( 0 );
63 $talk = $wgLang->getNsText( NS_TALK );
64 $mwtalk = $wgLang->getNsText( NS_MEDIAWIKI_TALK );
65
66 foreach ( $sortedArray as $key => $enMsg ) {
67 $message = wfMsgNoDB( $key );
68 $titleObj = Title::newFromText( $key );
69 $title = $titleObj->getDBkey();
70 $dbencMsg = wfStrencode( $message );
71
72 $doInsert = true;
73 if ( $overwrite ) {
74 wfQuery( "DELETE FROM cur WHERE cur_namespace=$ns AND cur_title='$title'", DB_WRITE, $fname );
75 } else {
76 if (array_key_exists($title, $exists)) {
77 $doInsert = false;
78 }
79 }
80 if ( $doInsert ) {
81 if ( $first ) {
82 $first = false;
83 } else {
84 $sql .= ",";
85 }
86 $sql .=
87 "($ns,
88 '$title',
89 '$dbencMsg',
90 'MediaWiki default',
91 '$timestamp',
92 'sysop',
93 1,
94 '$invTimestamp',
95 '$timestamp')";
96 }
97 $mw = str_replace( "$1", $key, $msgnw );
98
99 $message = wfEscapeWikiText( $message );
100 $navText .=
101 "<tr><td>
102 [$wgServer$wgScript?title=MediaWiki:$title&action=edit $key]<br>
103 [[$mwtalk:$title|$talk]]
104 </td><td>
105 $message
106 </td><td>
107 $mw
108 </td></tr>";
109 }
110
111 if ( !$first ) {
112 wfQuery( $sql, DB_WRITE, $fname );
113 }
114
115
116 $navText .= "</table>";
117
118 $title = wfMsgNoDB( "allmessages" );
119 $titleObj = Title::makeTitle( NS_MEDIAWIKI, $title );
120 $wgArticle = new Article( $titleObj );
121 $wgOut->disable();
122 $wgUser = User::newFromName( 'MediaWiki default' );
123 if ( $titleObj->getArticleID() ) {
124 $wgArticle->updateArticle( $navText, '', 0, 0 );
125 } else {
126 $wgArticle->insertNewArticle( $navText, '', 0, 0 );
127 }
128
129 if( $wgDatabaseMessages ) {
130 print "Clearing message cache...";
131 $wgMemc->delete( "$wgDBname:messages" );
132 print "Done.\n";
133 }
134
135 }
136
137 ?>