9 require_once( "LinksUpdate.php" );
14 function wfSpecialMakesysop() {
15 global $wgUser, $wgOut, $wgRequest;
17 if ( 0 == $wgUser->getID() or $wgUser->isBlocked() ) {
18 $wgOut->errorpage( "movenologin", "movenologintext" );
21 if (! $wgUser->isBureaucrat() && ! $wgUser->isDeveloper() ){
22 $wgOut->errorpage( "bureaucrattitle", "bureaucrattext" );
27 $wgOut->readOnlyPage();
31 $f = new MakesysopForm( $wgRequest );
44 var $mTarget, $mAction, $mRights, $mUser, $mSubmit;
46 function MakesysopForm( &$request ) {
47 $this->mAction
= $request->getText( 'action' );
48 $this->mRights
= $request->getVal( 'wpRights' );
49 $this->mUser
= $request->getText( 'wpMakesysopUser' );
50 $this->mSubmit
= $request->getBool( 'wpMakesysopSubmit' ) && $request->wasPosted();
51 $this->mBuro
= $request->getBool( 'wpSetBureaucrat' );
54 function showForm( $err = '') {
55 global $wgOut, $wgUser, $wgLang;
57 if ( $wgUser->isDeveloper() ) {
58 $wgOut->setPageTitle( wfMsg( "set_user_rights" ) );
60 $wgOut->setPagetitle( wfMsg( "makesysoptitle" ) );
63 $wgOut->addWikiText( wfMsg( "makesysoptext" ) );
65 $titleObj = Title
::makeTitle( NS_SPECIAL
, "Makesysop" );
66 $action = $titleObj->escapeLocalURL( "action=submit" );
69 $wgOut->setSubtitle( wfMsg( "formerror" ) );
70 $wgOut->addHTML( "<p class='error'>{$err}</p>\n" );
72 $namedesc = wfMsg( "makesysopname" );
73 if ( !is_null( $this->mUser
) ) {
74 $encUser = htmlspecialchars( $this->mUser
);
80 <form id=\"makesysop\" method=\"post\" action=\"{$action}\">
83 <td align='right'>$namedesc</td>
85 <input type='text' size='40' name=\"wpMakesysopUser\" value=\"$encUser\" />
90 $makeburo = wfMsg( "setbureaucratflag" );
93 <td> </td><td align=left>
94 <input type=checkbox name=\"wpSetBureaucrat\" value=1>$makeburo
99 if ( $wgUser->isDeveloper() ) {
100 $rights = wfMsg( "rights" );
101 if ( !is_null( $this->mRights
) ) {
102 $encRights = htmlspecialchars( $this->mRights
);
104 $encRights = "sysop";
109 <td align='right'>$rights</td>
111 <input type='text' size='40' name=\"wpRights\" value=\"$encRights\" />
117 if ( $wgUser->isDeveloper() ) {
118 $mss = wfMsg( "set_user_rights" );
120 $mss = wfMsg( "makesysopsubmit" );
124 <td> </td><td align='left'>
125 <input type='submit' name=\"wpMakesysopSubmit\" value=\"{$mss}\" />
132 function doSubmit() {
133 global $wgOut, $wgUser, $wgLang;
134 global $wgDBname, $wgMemc, $wgLocalDatabases;
136 $fname = 'MakesysopForm::doSubmit';
138 $dbw =& wfGetDB( DB_MASTER
);
139 $parts = explode( '@', $this->mUser
);
140 $user_rights = $dbw->tableName( 'user_rights' );
141 $usertable = $dbw->tableName( 'user' );
143 if( count( $parts ) == 2 && $wgUser->isDeveloper() && strpos( '.', $user_rights ) === false ){
144 $username = $dbw->strencode( $parts[0] );
145 if ( array_key_exists( $parts[1], $wgLocalDatabases ) ) {
146 $dbName = $wgLocalDatabases[$parts[1]];
147 $user_rights = $dbName . '.' . $user_rights;
148 $usertable = $usertable . '.' . $usertable;
154 $username = wfStrencode( $this->mUser
);
157 if ( $username{0} == "#" ) {
158 $id = intval( substr( $username, 1 ) );
159 $sql = "SELECT user_id,user_rights FROM $user_rights WHERE user_id=$id FOR UPDATE";
161 $encName = $dbw->strencode( $username );
162 $sql = "SELECT u.user_id, user_rights FROM $usertable u LEFT JOIN $user_rights r ON u.user_id=r.user_id WHERE user_name = '{$username}' FOR UPDATE";
165 $prev = $dbw->ignoreErrors( TRUE );
166 $res = $dbw->query( $sql );
167 $dbw->ignoreErrors( $prev );
169 if( $dbw->lastErrno() ||
! $username ||
$dbw->numRows( $res ) == 0 ){
174 $row = $dbw->fetchObject( $res );
175 $id = intval( $row->user_id
);
176 $rightsNotation = array();
178 if ( $wgUser->isDeveloper() ) {
179 $newrights = (string)$this->mRights
;
180 $rightsNotation[] = "=$this->mRights";
182 if( $row->user_rights
){
183 $rights = explode(",", $row->user_rights
);
184 if(! in_array("sysop", $rights ) ){
186 $rightsNotation[] = "+sysop ";
188 if ( $this->mBuro
&& !in_array( "bureaucrat", $rights ) ) {
189 $rights[] = "bureaucrat";
190 $rightsNotation[] = "+bureaucrat ";
192 $newrights = addslashes( implode( ",", $rights ) );
194 $newrights = "sysop";
195 $rightsNotation[] = "+sysop";
196 if ( $this->mBuro
) {
197 $rightsNotation[] = "+bureaucrat";
198 $newrights .= ",bureaucrat";
203 if ( count( $rightsNotation ) == 0 ) {
206 #$sql = "UPDATE $user_rights SET user_rights = '{$newrights}' WHERE user_id = $id LIMIT 1";
208 $dbw->replace( $user_rights, array( array( 'user_id', 'user_rights' )),
209 array( 'user_id' => $id, 'user_rights' => $newrights ) , $fname );
210 $wgMemc->delete( "$dbName:user:id:$id" );
212 $log = new LogPage( 'rights' );
213 $log->addEntry( 'rights', Title
::makeTitle( NS_USER
, $this->mUser
),
214 implode( " ", $rightsNotation ) );
216 $this->showSuccess();
220 function showSuccess() {
221 global $wgOut, $wgUser;
223 $wgOut->setPagetitle( wfMsg( "makesysoptitle" ) );
225 if ( $wgUser->isDeveloper() ) {
226 $text = wfMsg( "user_rights_set", $this->mUser
);
228 $text = wfMsg( "makesysopok", $this->mUser
);
231 $wgOut->addWikiText( $text );
236 function showFail() {
237 global $wgOut, $wgUser;
239 $wgOut->setPagetitle( wfMsg( "makesysoptitle" ) );
240 if ( $wgUser->isDeveloper() ) {
241 $this->showForm( wfMsg( "set_rights_fail", $this->mUser
) );
243 $this->showForm( wfMsg( "makesysopfail", $this->mUser
) );