Refactored (object-orientified) to make them play nice with $wgRequest

This commit is contained in:
Tim Starling 2004-04-01 13:03:05 +00:00
parent 57bfb02e4d
commit 549d49951e
5 changed files with 991 additions and 944 deletions

View file

@ -3,7 +3,7 @@ include_once( "LinksUpdate.php" );
function wfSpecialMakesysop()
{
global $wgUser, $wgOut, $action, $target;
global $wgUser, $wgOut, $wgRequest;
if ( 0 == $wgUser->getID() or $wgUser->isBlocked() ) {
$wgOut->errorpage( "movenologin", "movenologintext" );
@ -13,26 +13,36 @@ function wfSpecialMakesysop()
$wgOut->errorpage( "bureaucrattitle", "bureaucrattext" );
return;
}
if ( wfReadOnly() ) {
$wgOut->readOnlyPage();
return;
}
$f = new MakesysopForm();
$f = new MakesysopForm( $wgRequest );
if ( $_POST['wpMakesysopSubmit'] ) {
if ( $f->mSubmit ) {
$f->doSubmit();
} else {
$f->showForm( "" );
}
}
class MakesysopForm {
class MakesysopForm {
var $mTarget, $mAction, $mRights, $mUser, $mSubmit;
function MakesysopForm( &$request )
{
$this->mAction = $request->getText( 'action' );
$this->mRights = $request->getVal( 'wpRights' );
$this->mUser = $request->getText( 'wpMakesysopUser' );
$this->mSubmit = $request->getBool( 'wpMakesysopSubmit' ) && $request->wasPosted();
$this->mBuro = $request->getBool( 'wpSetBureaucrat' );
}
function showForm( $err = "")
{
global $wgOut, $wgUser, $wgLang;
global $wpNewTitle, $wpOldTitle, $wpMovetalk, $target, $wpRights, $wpMakesysopUser;
if ( $wgUser->isDeveloper() ) {
$wgOut->setPageTitle( wfMsg( "set_user_rights" ) );
@ -50,8 +60,8 @@ class MakesysopForm {
$wgOut->addHTML( "<p><font color='red' size='+1'>{$err}</font>\n" );
}
$namedesc = wfMsg( "makesysopname" );
if ( isset( $wpMakesysopUser ) ) {
$encUser = htmlspecialchars( $wpMakesysopUser );
if ( !is_null( $this->mUser ) ) {
$encUser = htmlspecialchars( $this->mUser );
} else {
$encUser = "";
}
@ -78,8 +88,8 @@ class MakesysopForm {
if ( $wgUser->isDeveloper() ) {
$rights = wfMsg( "rights" );
if ( isset( $wpRights ) ) {
$encRights = htmlspecialchars( $wpRights );
if ( !is_null( $this->mRights ) ) {
$encRights = htmlspecialchars( $this->mRights );
} else {
$encRights = "sysop";
}
@ -111,41 +121,10 @@ class MakesysopForm {
function doSubmit()
{
global $wgOut, $wgUser, $wgLang;
global $wgDBname, $wgMemc, $wgLocalDatabases;
global $wgOut, $wgUser, $wgLang, $wpMakesysopUser, $wpSetBureaucrat;
global $wgDBname, $wgMemc, $wpRights, $wgLocalDatabases;
$parts = explode( "@", $wpMakesysopUser );
if( count( $parts ) == 2 && $wgUser->isDeveloper() ){
$username = $parts[0];
if ( array_key_exists( $parts[1], $wgLocalDatabases ) ) {
$dbName = $wgLocalDatabases[$parts[1]];
$usertable = $dbName . ".user";
} else {
$this->showFail();
return;
}
} else {
$username = $wpMakesysopUser;
$usertable = "user";
$dbName = $wgDBname;
}
if ( $username{0} == "#" ) {
$id = intval( substr( $username, 1 ) );
$sql = "SELECT user_id,user_rights FROM $usertable WHERE user_id=$id";
} else {
$encName = wfStrencode( $username );
$sql = "SELECT user_id, user_rights FROM $usertable WHERE user_name = '{$encName}'";
}
$prev = wfIgnoreSQLErrors( TRUE );
$res = wfQuery( $sql, DB_WRITE);
wfIgnoreSQLErrors( $prev );
global $wgOut, $wgUser, $wgLang, $wpMakesysopUser, $wpSetBureaucrat;
global $wgDBname, $wgMemc, $wpRights, $wgLocalDatabases;
$parts = explode( "@", $wpMakesysopUser );
$parts = explode( "@", $this->mUser );
if( count( $parts ) == 2 && $wgUser->isDeveloper() ){
$username = wfStrencode( $parts[0] );
if ( array_key_exists( $parts[1], $wgLocalDatabases ) ) {
@ -156,18 +135,17 @@ class MakesysopForm {
return;
}
} else {
$username = wfStrencode( $wpMakesysopUser );
$username = wfStrencode( $this->mUser );
$usertable = "user";
$dbName = $wgDBname;
}
if ( $username{0} == "#" ) {
$id = intval( substr( $username, 1 ) );
$sql = "SELECT user_id,user_rights FROM $usertable WHERE user_id=$id";
} else {
$encName = wfStrencode( $username );
$sql = "SELECT user_id, user_rights FROM $usertable WHERE user_name = '{$username}'";
}
$id = intval( substr( $username, 1 ) );
$sql = "SELECT user_id,user_rights FROM $usertable WHERE user_id=$id";
} else {
$encName = wfStrencode( $username );
$sql = "SELECT user_id, user_rights FROM $usertable WHERE user_name = '{$username}'";
}
$prev = wfIgnoreSQLErrors( TRUE );
$res = wfQuery("SELECT user_id, user_rights FROM $usertable WHERE user_name = '{$username}'", DB_WRITE);
@ -183,8 +161,8 @@ class MakesysopForm {
$rightsNotation = array();
if ( $wgUser->isDeveloper() ) {
$newrights = (string)$wpRights;
$rightsNotation[] = "=$wpRights";
$newrights = (string)$this->mRights;
$rightsNotation[] = "=$this->mRights";
} else {
if( $row->user_rights ){
$rights = explode(",", $row->user_rights );
@ -192,7 +170,7 @@ class MakesysopForm {
$rights[] = "sysop";
$rightsNotation[] = "+sysop ";
}
if ( $wpSetBureaucrat && !in_array( "bureaucrat", $rights ) ) {
if ( $this->mBuro && !in_array( "bureaucrat", $rights ) ) {
$rights[] = "bureaucrat";
$rightsNotation[] = "+bureaucrat ";
}
@ -200,7 +178,7 @@ class MakesysopForm {
} else {
$newrights = "sysop";
$rightsNotation[] = "+sysop";
if ( $wpSetBureaucrat ) {
if ( $this->mBuro ) {
$rightsNotation[] = "+bureaucrat";
$newrights .= ",bureaucrat";
}
@ -215,7 +193,7 @@ class MakesysopForm {
$wgMemc->delete( "$dbName:user:id:$id" );
$bureaucratLog = wfMsg( "bureaucratlog" );
$action = wfMsg( "bureaucratlogentry", $wpMakesysopUser, implode( " ", $rightsNotation ) );
$action = wfMsg( "bureaucratlogentry", $this->mUser, implode( " ", $rightsNotation ) );
$log = new LogPage( $bureaucratLog );
$log->addEntry( $action, "" );
@ -226,14 +204,14 @@ class MakesysopForm {
function showSuccess()
{
global $wgOut, $wpMakesysopUser, $wgUser;
global $wgOut, $wgUser;
$wgOut->setPagetitle( wfMsg( "makesysoptitle" ) );
if ( $wgUser->isDeveloper() ) {
$text = wfMsg( "user_rights_set", $wpMakesysopUser );
$text = wfMsg( "user_rights_set", $this->mUser );
} else {
$text = wfMsg( "makesysopok", $wpMakesysopUser );
$text = wfMsg( "makesysopok", $this->mUser );
}
$text .= "\n\n";
$wgOut->addWikiText( $text );
@ -243,13 +221,13 @@ class MakesysopForm {
function showFail()
{
global $wgOut, $wpMakesysopUser, $wgUser;
global $wgOut, $wgUser;
$wgOut->setPagetitle( wfMsg( "makesysoptitle" ) );
if ( $wgUser->isDeveloper() ) {
$this->showForm( wfMsg( "set_rights_fail", $wpMakesysopUser ) );
$this->showForm( wfMsg( "set_rights_fail", $this->mUser ) );
} else {
$this->showForm( wfMsg( "makesysopfail", $wpMakesysopUser ) );
$this->showForm( wfMsg( "makesysopfail", $this->mUser ) );
}
}
}

View file

@ -2,402 +2,426 @@
function wfSpecialPreferences()
{
global $wgUser, $wgOut, $wgUseDynamicDates, $action;
global $wpSaveprefs, $wpReset, $wgRequest;
global $wgRequest;
# EWWWWWW temp hack
global $wpOldpass, $wpNewpass, $wpRetypePass, $wpNick, $wpUserEmail;
$wpOldpass = $wgRequest->getText( 'wpOldpass' );
$wpNewpass = $wgRequest->getText( 'wpNewpass' );
$wpRetypePass = $wgRequest->getText( 'wpRetypePass' );
$wpNick = $wgRequest->getText( 'wpNick' );
$wpUserEmail = $wgRequest->getVal( 'wpUserEmail' );
if ( 0 == $wgUser->getID() ) {
$wgOut->errorpage( "prefsnologin", "prefsnologintext" );
return;
}
if ( wfReadOnly() ) {
$wgOut->readOnlyPage();
return;
}
if ( isset( $wpReset ) ) {
resetPrefs();
mainPrefsForm( WfMsg( "prefsreset" ) );
} else if ( isset( $_POST['wpSaveprefs'] ) ) {
savePreferences();
} else {
resetPrefs();
mainPrefsForm( "" );
}
$form = new PreferencesForm( $wgRequest );
$form->execute();
}
/* private */ function validateInt( &$val, $min=0, $max=0x7fffffff ) {
$val = intval($val);
$val = min($val, $max);
$val = max($val, $min);
return $val;
}
class PreferencesForm {
var $mQuickbar, $mOldpass, $mNewpass, $mRetypePass, $mStubs;
var $mRows, $mCols, $mSkin, $mMath, $mDate, $mUserEmail, $mEmailFlag, $mNick;
var $mSearch, $mRecent, $mHourDiff, $mSearchLines, $mSearchChars, $mAction;
var $mReset, $mPosted, $mToggles, $mSearchNs;
/* private */ function validateIntOrNull( &$val, $min=0, $max=0x7fffffff ) {
$val = trim($val);
if($val === "") {
return $val;
} else {
return validateInt( $val, $min, $max );
}
}
function PreferencesForm( &$request ) {
global $wgLang;
$this->mQuickbar = $request->getVal( 'wpQuickbar' );
$this->mOldpass = $request->getVal( 'wpOldpass' );
$this->mNewpass = $request->getVal( 'wpNewpass' );
$this->mRetypePass =$request->getVal( 'wpRetypePass' );
$this->mStubs = $request->getVal( 'wpStubs' );
$this->mRows = $request->getVal( 'wpRows' );
$this->mCols = $request->getVal( 'wpCols' );
$this->mSkin = $request->getVal( 'wpSkin' );
$this->mMath = $request->getVal( 'wpMath' );
$this->mDate = $request->getVal( 'wpDate' );
$this->mUserEmail = $request->getVal( 'wpUserEmail' );
$this->mEmailFlag = $request->getCheck( 'wpEmailFlag' ) ? 1 : 0;
$this->mNick = $request->getVal( 'wpNick' );
$this->mSearch = $request->getVal( 'wpSearch' );
$this->mRecent = $request->getVal( 'wpRecent' );
$this->mHourDiff = $request->getVal( 'wpHourDiff' );
$this->mSearchLines = $request->getVal( 'wpSearchLines' );
$this->mSearchChars = $request->getVal( 'wpSearchChars' );
$this->mAction = $request->getVal( 'action' );
$this->mReset = $request->getCheck( 'wpReset' );
$this->mPosted = $request->wasPosted();
$this->mSaveprefs = $request->getCheck( 'wpSaveprefs' ) && $this->mPosted;
/* private */ function validateCheckbox( $cb )
{
if ( $cb )
{
return 1;
}
else
{
return 0;
}
}
/* private */ function validateTimeZone( $s )
{
if ( $s !== "" ) {
if ( strpos( $s, ":" ) ) {
# HH:MM
$array = explode( ":" , $s );
$hour = intval( $array[0] );
$minute = intval( $array[1] );
} else {
$minute = intval( $s * 60 );
$hour = intval( $minute / 60 );
$minute = abs( $minute ) % 60;
# User toggles (the big ugly unsorted list of checkboxes)
$this->mToggles = array();
if ( $this->mPosted ) {
$togs = $wgLang->getUserToggles();
foreach ( $togs as $tname => $ttext ) {
$this->mToggles[$tname] = $request->getCheck( "wpOp$tname" ) ? 1 : 0;
}
}
# Search namespace options
# Note: namespaces don't necessarily have consecutive keys
$this->mSearchNs = array();
if ( $this->mPosted ) {
$namespaces = $wgLang->getNamespaces();
foreach ( $namespaces as $i => $namespace ) {
if ( $i >= 0 ) {
$this->mSearchNs[$i] = $request->getCheck( "wpNs$i" ) ? 1 : 0;
}
}
}
$hour = min( $hour, 15 );
$hour = max( $hour, -15 );
$minute = min( $minute, 59 );
$minute = max( $minute, 0 );
$s = sprintf( "%02d:%02d", $hour, $minute );
}
return $s;
}
/* private */ function savePreferences()
{
global $wgUser, $wgLang, $wgDeferredUpdateList;
global $wpQuickbar, $wpOldpass, $wpNewpass, $wpRetypePass;
global $wpSkin, $wpMath, $wpDate, $wpUserEmail, $wpEmailFlag, $wpNick, $wpSearch, $wpRecent;
global $wpSearchLines, $wpSearchChars, $wpStubs;
global $wpRows, $wpCols, $wpHourDiff;
if ( "" != $wpNewpass ) {
if ( $wpNewpass != $wpRetypePass ) {
mainPrefsForm( wfMsg( "badretype" ) );
function execute() {
global $wgUser, $wgOut, $wgUseDynamicDates;
if ( 0 == $wgUser->getID() ) {
$wgOut->errorpage( "prefsnologin", "prefsnologintext" );
return;
}
$ep = $wgUser->encryptPassword( $wpOldpass );
if ( $ep != $wgUser->getPassword() ) {
if ( $ep != $wgUser->getNewpassword() ) {
mainPrefsForm( wfMsg( "wrongpassword" ) );
if ( wfReadOnly() ) {
$wgOut->readOnlyPage();
return;
}
if ( $this->mReset ) {
$this->resetPrefs();
$this->mainPrefsForm( wfMsg( "prefsreset" ) );
} else if ( $this->mSaveprefs ) {
$this->savePreferences();
} else {
$this->resetPrefs();
$this->mainPrefsForm( "" );
}
}
/* private */ function validateInt( &$val, $min=0, $max=0x7fffffff ) {
$val = intval($val);
$val = min($val, $max);
$val = max($val, $min);
return $val;
}
/* private */ function validateIntOrNull( &$val, $min=0, $max=0x7fffffff ) {
$val = trim($val);
if($val === "") {
return $val;
} else {
return $this->validateInt( $val, $min, $max );
}
}
/* private */ function validateTimeZone( $s )
{
if ( $s !== "" ) {
if ( strpos( $s, ":" ) ) {
# HH:MM
$array = explode( ":" , $s );
$hour = intval( $array[0] );
$minute = intval( $array[1] );
} else {
$minute = intval( $s * 60 );
$hour = intval( $minute / 60 );
$minute = abs( $minute ) % 60;
}
$hour = min( $hour, 15 );
$hour = max( $hour, -15 );
$minute = min( $minute, 59 );
$minute = max( $minute, 0 );
$s = sprintf( "%02d:%02d", $hour, $minute );
}
return $s;
}
/* private */ function savePreferences()
{
global $wgUser, $wgLang, $wgDeferredUpdateList;
if ( "" != $this->mNewpass ) {
if ( $this->mNewpass != $this->mRetypePass ) {
$this->mainPrefsForm( wfMsg( "badretype" ) );
return;
}
$ep = $wgUser->encryptPassword( $this->mOldpass );
if ( $ep != $wgUser->getPassword() ) {
if ( $ep != $wgUser->getNewpassword() ) {
$this->mainPrefsForm( wfMsg( "wrongpassword" ) );
return;
}
}
$wgUser->setPassword( $this->mNewpass );
}
$wgUser->setPassword( $wpNewpass );
$wgUser->setEmail( $this->mUserEmail );
$wgUser->setOption( "nickname", $this->mNick );
$wgUser->setOption( "quickbar", $this->mQuickbar );
$wgUser->setOption( "skin", $this->mSkin );
$wgUser->setOption( "math", $this->mMath );
$wgUser->setOption( "date", $this->mDate );
$wgUser->setOption( "searchlimit", $this->validateIntOrNull( $this->mSearch ) );
$wgUser->setOption( "contextlines", $this->validateIntOrNull( $this->mSearchLines ) );
$wgUser->setOption( "contextchars", $this->validateIntOrNull( $this->mSearchChars ) );
$wgUser->setOption( "rclimit", $this->validateIntOrNull( $this->mRecent ) );
$wgUser->setOption( "rows", $this->validateInt( $this->mRows, 4, 1000 ) );
$wgUser->setOption( "cols", $this->validateInt( $this->mCols, 4, 1000 ) );
$wgUser->setOption( "stubthreshold", $this->validateIntOrNull( $this->mStubs ) );
$wgUser->setOption( "timecorrection", $this->validateTimeZone( $this->mHourDiff, -12, 14 ) );
# Set search namespace options
foreach( $this->mSearchNs as $i => $value ) {
$wgUser->setOption( "searchNs{$i}", $value );
}
$wgUser->setOption( "disablemail", $this->mEmailFlag );
# Set user toggles
foreach ( $this->mToggles as $tname => $tvalue ) {
$wgUser->setOption( $tname, $tvalue );
}
$wgUser->setCookies();
$up = new UserUpdate();
array_push( $wgDeferredUpdateList, $up );
$this->mainPrefsForm( wfMsg( "savedprefs" ) );
}
$wgUser->setEmail( $wpUserEmail );
$wgUser->setOption( "nickname", $wpNick );
$wgUser->setOption( "quickbar", $wpQuickbar );
$wgUser->setOption( "skin", $wpSkin );
$wgUser->setOption( "math", $wpMath );
$wgUser->setOption( "date", $wpDate );
$wgUser->setOption( "searchlimit", validateIntOrNull( $wpSearch ) );
$wgUser->setOption( "contextlines", validateIntOrNull( $wpSearchLines ) );
$wgUser->setOption( "contextchars", validateIntOrNull( $wpSearchChars ) );
$wgUser->setOption( "rclimit", validateIntOrNull( $wpRecent ) );
$wgUser->setOption( "rows", validateInt( $wpRows, 4, 1000 ) );
$wgUser->setOption( "cols", validateInt( $wpCols, 4, 1000 ) );
$wgUser->setOption( "stubthreshold", validateIntOrNull( $wpStubs ) );
$wgUser->setOption( "timecorrection", validateTimeZone( $wpHourDiff, -12, 14 ) );
$namespaces = $wgLang->getNamespaces();
# Set search namespace options
# Note: namespaces don't necessarily have consecutive keys
foreach ( $namespaces as $i => $namespaces ) {
if ( $i >= 0 ) {
$nsvar = "wpNs$i";
global $$nsvar;
$wgUser->setOption( "searchNs{$i}", validateCheckbox( $$nsvar ) );
/* private */ function resetPrefs()
{
global $wgUser, $wgLang;
$this->mOldpass = $this->mNewpass = $this->mRetypePass = "";
$this->mUserEmail = $wgUser->getEmail();
if ( 1 == $wgUser->getOption( "disablemail" ) ) { $this->mEmailFlag = 1; }
else { $this->mEmailFlag = 0; }
$this->mNick = $wgUser->getOption( "nickname" );
$this->mQuickbar = $wgUser->getOption( "quickbar" );
$this->mSkin = $wgUser->getOption( "skin" );
$this->mMath = $wgUser->getOption( "math" );
$this->mDate = $wgUser->getOption( "date" );
$this->mRows = $wgUser->getOption( "rows" );
$this->mCols = $wgUser->getOption( "cols" );
$this->mStubs = $wgUser->getOption( "stubthreshold" );
$this->mHourDiff = $wgUser->getOption( "timecorrection" );
$this->mSearch = $wgUser->getOption( "searchlimit" );
$this->mSearchLines = $wgUser->getOption( "contextlines" );
$this->mSearchChars = $wgUser->getOption( "contextchars" );
$this->mRecent = $wgUser->getOption( "rclimit" );
$togs = $wgLang->getUserToggles();
foreach ( $togs as $tname => $ttext ) {
$this->mToggles[$tname] = $wgUser->getOption( $tname );
}
$namespaces = $wgLang->getNamespaces();
foreach ( $namespaces as $i => $namespace ) {
if ( $i >= 0 ) {
$this->mSearchNs[$i] = $wgUser->getOption( "searchNs$i" );
}
}
}
$wgUser->setOption( "disablemail", validateCheckbox( $wpEmailFlag ) );
/* private */ function namespacesCheckboxes()
{
global $wgLang, $wgUser;
# Determine namespace checkboxes
$namespaces = $wgLang->getNamespaces();
$r1 = "";
$togs = $wgLang->getUserToggles();
foreach ( $togs as $tname => $ttext ) {
if ( array_key_exists( "wpOp$tname", $_POST ) ) {
$wgUser->setOption( $tname, 1 );
foreach ( $namespaces as $i => $name ) {
# Skip special or anything similar
if ( $i >= 0 ) {
$checked = "";
if ( $this->mSearchNs[$i] ) {
$checked = " checked";
}
$name = str_replace( "_", " ", $namespaces[$i] );
if ( "" == $name ) {
$name = wfMsg( "blanknamespace" );
}
if ( 0 != $i ) {
$r1 .= " ";
}
$r1 .= "<label><input type=checkbox value=\"1\" name=\"" .
"wpNs$i\"{$checked}>{$name}</label>\n";
}
}
return $r1;
}
/* private */ function mainPrefsForm( $err )
{
global $wgUser, $wgOut, $wgLang, $wgUseDynamicDates, $wgValidSkinNames;
$wgOut->setPageTitle( wfMsg( "preferences" ) );
$wgOut->setArticleRelated( false );
$wgOut->setRobotpolicy( "noindex,nofollow" );
if ( "" != $err ) {
$wgOut->addHTML( "<font size='+1' color='red'>$err</font>\n<p>" );
}
$uname = $wgUser->getName();
$uid = $wgUser->getID();
$wgOut->addWikiText( wfMsg( "prefslogintext", $uname, $uid ) );
$qbs = $wgLang->getQuickbarSettings();
$skinNames = $wgLang->getSkinNames();
$mathopts = $wgLang->getMathNames();
$dateopts = $wgLang->getDateFormats();
$togs = $wgLang->getUserToggles();
$titleObj = Title::makeTitle( NS_SPECIAL, "Preferences" );
$action = $titleObj->escapeLocalURL();
$qb = wfMsg( "qbsettings" );
$cp = wfMsg( "changepassword" );
$sk = wfMsg( "skin" );
$math = wfMsg( "math" );
$dateFormat = wfMsg("dateformat");
$opw = wfMsg( "oldpassword" );
$npw = wfMsg( "newpassword" );
$rpw = wfMsg( "retypenew" );
$svp = wfMsg( "saveprefs" );
$rsp = wfMsg( "resetprefs" );
$tbs = wfMsg( "textboxsize" );
$tbr = wfMsg( "rows" );
$tbc = wfMsg( "columns" );
$ltz = wfMsg( "localtime" );
$tzt = wfMsg( "timezonetext" );
$tzo = wfMsg( "timezoneoffset" );
$tzGuess = wfMsg( "guesstimezone" );
$tzServerTime = wfMsg( "servertime" );
$yem = wfMsg( "youremail" );
$emf = wfMsg( "emailflag" );
$ynn = wfMsg( "yournick" );
$stt = wfMsg ( "stubthreshold" ) ;
$srh = wfMsg( "searchresultshead" );
$rpp = wfMsg( "resultsperpage" );
$scl = wfMsg( "contextlines" );
$scc = wfMsg( "contextchars" );
$rcc = wfMsg( "recentchangescount" );
$dsn = wfMsg( "defaultns" );
$wgOut->addHTML( "<form id=\"preferences\" name=\"preferences\" action=\"$action\"
method=\"post\"><table border=\"1\"><tr><td valign=top nowrap><b>$qb:</b><br>\n" );
# Quickbar setting
#
for ( $i = 0; $i < count( $qbs ); ++$i ) {
if ( $i == $this->mQuickbar ) { $checked = " checked"; }
else { $checked = ""; }
$wgOut->addHTML( "<label><input type=radio name=\"wpQuickbar\"
value=\"$i\"$checked> {$qbs[$i]}</label><br>\n" );
}
# Fields for changing password
#
$this->mOldpass = wfEscapeHTML( $this->mOldpass );
$this->mNewpass = wfEscapeHTML( $this->mNewpass );
$this->mRetypePass = wfEscapeHTML( $this->mRetypePass );
$wgOut->addHTML( "</td><td vaign=top nowrap><b>$cp:</b><br>
<label>$opw: <input type=password name=\"wpOldpass\" value=\"{$this->mOldpass}\" size=20></label><br>
<label>$npw: <input type=password name=\"wpNewpass\" value=\"{$this->mNewpass}\" size=20></label><br>
<label>$rpw: <input type=password name=\"wpRetypePass\" value=\"{$this->mRetypePass}\" size=20></label><br>
</td></tr>\n" );
# Skin setting
#
$wgOut->addHTML( "<tr><td valign=top nowrap><b>$sk:</b><br>\n" );
# Only show members of $wgValidSkinNames rather than
# $skinNames (skins is all skin names from Language.php)
foreach ($wgValidSkinNames as $skinkey => $skinname ) {
if ( $skinkey == $this->mSkin ) {
$checked = ' checked';
} else {
$checked = "";
}
$wgOut->addHTML( "<label><input type=radio name=\"wpSkin\"
value=\"$skinkey\"$checked> {$skinNames[$skinkey]}</label><br>\n" );
}
# Various checkbox options
#
if ( $wgUseDynamicDates ) {
$wgOut->addHTML( "</td><td rowspan=3 valign=top nowrap>\n" );
} else {
$wgUser->setOption( $tname, 0 );
$wgOut->addHTML( "</td><td rowspan=2 valign=top nowrap>\n" );
}
}
$wgUser->setCookies();
$up = new UserUpdate();
array_push( $wgDeferredUpdateList, $up );
mainPrefsForm( wfMsg( "savedprefs" ) );
}
/* private */ function resetPrefs()
{
global $wgUser, $wgLang;
global $wpQuickbar, $wpOldpass, $wpNewpass, $wpRetypePass, $wpStubs;
global $wpRows, $wpCols, $wpSkin, $wpMath, $wpDate, $wpUserEmail, $wpEmailFlag, $wpNick;
global $wpSearch, $wpRecent;
global $wpHourDiff, $wpSearchLines, $wpSearchChars;
$wpOldpass = $wpNewpass = $wpRetypePass = "";
$wpUserEmail = $wgUser->getEmail();
if ( 1 == $wgUser->getOption( "disablemail" ) ) { $wpEmailFlag = 1; }
else { $wpEmailFlag = 0; }
$wpNick = $wgUser->getOption( "nickname" );
$wpQuickbar = $wgUser->getOption( "quickbar" );
$wpSkin = $wgUser->getOption( "skin" );
$wpMath = $wgUser->getOption( "math" );
$wpDate = $wgUser->getOption( "date" );
$wpRows = $wgUser->getOption( "rows" );
$wpCols = $wgUser->getOption( "cols" );
$wpStubs = $wgUser->getOption( "stubthreshold" );
$wpHourDiff = $wgUser->getOption( "timecorrection" );
$wpSearch = $wgUser->getOption( "searchlimit" );
$wpSearchLines = $wgUser->getOption( "contextlines" );
$wpSearchChars = $wgUser->getOption( "contextchars" );
$wpRecent = $wgUser->getOption( "rclimit" );
$togs = $wgLang->getUserToggles();
foreach ( $togs as $tname => $ttext ) {
$_POST["wpOp$tname"] = $wgUser->getOption( $tname );
}
}
/* private */ function namespacesCheckboxes()
{
global $wgLang, $wgUser;
# Determine namespace checkboxes
$namespaces = $wgLang->getNamespaces();
$r1 = "";
foreach ( $namespaces as $i => $name ) {
# Skip special or anything similar
if ( $i >= 0 ) {
$checked = "";
if ( $wgUser->getOption( "searchNs$i" ) ) {
$checked = " checked";
}
$name = str_replace( "_", " ", $namespaces[$i] );
if ( "" == $name ) {
$name = wfMsg( "blanknamespace" );
}
if ( 0 != $i ) {
$r1 .= " ";
}
$r1 .= "<label><input type=checkbox value=\"1\" name=\"" .
"wpNs$i\"{$checked}>{$name}</label>\n";
}
}
return $r1;
}
/* private */ function mainPrefsForm( $err )
{
global $wgUser, $wgOut, $wgLang, $wgUseDynamicDates;
global $wpQuickbar, $wpOldpass, $wpNewpass, $wpRetypePass;
global $wpSkin, $wpMath, $wpDate, $wpUserEmail, $wpEmailFlag, $wpNick, $wpSearch, $wpRecent;
global $wpRows, $wpCols, $wpSaveprefs, $wpReset, $wpHourDiff;
global $wpSearchLines, $wpSearchChars, $wpStubs, $wgValidSkinNames;
$wgOut->setPageTitle( wfMsg( "preferences" ) );
$wgOut->setArticleRelated( false );
$wgOut->setRobotpolicy( "noindex,nofollow" );
if ( "" != $err ) {
$wgOut->addHTML( "<font size='+1' color='red'>$err</font>\n<p>" );
}
$uname = $wgUser->getName();
$uid = $wgUser->getID();
$wgOut->addWikiText( wfMsg( "prefslogintext", $uname, $uid ) );
$qbs = $wgLang->getQuickbarSettings();
$skinNames = $wgLang->getSkinNames();
$mathopts = $wgLang->getMathNames();
$dateopts = $wgLang->getDateFormats();
$togs = $wgLang->getUserToggles();
$titleObj = Title::makeTitle( NS_SPECIAL, "Preferences" );
$action = $titleObj->escapeLocalURL();
$qb = wfMsg( "qbsettings" );
$cp = wfMsg( "changepassword" );
$sk = wfMsg( "skin" );
$math = wfMsg( "math" );
$dateFormat = wfMsg("dateformat");
$opw = wfMsg( "oldpassword" );
$npw = wfMsg( "newpassword" );
$rpw = wfMsg( "retypenew" );
$svp = wfMsg( "saveprefs" );
$rsp = wfMsg( "resetprefs" );
$tbs = wfMsg( "textboxsize" );
$tbr = wfMsg( "rows" );
$tbc = wfMsg( "columns" );
$ltz = wfMsg( "localtime" );
$tzt = wfMsg( "timezonetext" );
$tzo = wfMsg( "timezoneoffset" );
$tzGuess = wfMsg( "guesstimezone" );
$tzServerTime = wfMsg( "servertime" );
$yem = wfMsg( "youremail" );
$emf = wfMsg( "emailflag" );
$ynn = wfMsg( "yournick" );
$stt = wfMsg ( "stubthreshold" ) ;
$srh = wfMsg( "searchresultshead" );
$rpp = wfMsg( "resultsperpage" );
$scl = wfMsg( "contextlines" );
$scc = wfMsg( "contextchars" );
$rcc = wfMsg( "recentchangescount" );
$dsn = wfMsg( "defaultns" );
$wgOut->addHTML( "<form id=\"preferences\" name=\"preferences\" action=\"$action\"
method=\"post\"><table border=\"1\"><tr><td valign=top nowrap><b>$qb:</b><br>\n" );
# Quickbar setting
#
for ( $i = 0; $i < count( $qbs ); ++$i ) {
if ( $i == $wpQuickbar ) { $checked = " checked"; }
else { $checked = ""; }
$wgOut->addHTML( "<label><input type=radio name=\"wpQuickbar\"
value=\"$i\"$checked> {$qbs[$i]}</label><br>\n" );
}
# Fields for changing password
#
$wpOldpass = wfEscapeHTML( $wpOldpass );
$wpNewpass = wfEscapeHTML( $wpNewpass );
$wpRetypePass = wfEscapeHTML( $wpRetypePass );
$wgOut->addHTML( "</td><td vaign=top nowrap><b>$cp:</b><br>
<label>$opw: <input type=password name=\"wpOldpass\" value=\"$wpOldpass\" size=20></label><br>
<label>$npw: <input type=password name=\"wpNewpass\" value=\"$wpNewpass\" size=20></label><br>
<label>$rpw: <input type=password name=\"wpRetypePass\" value=\"$wpRetypePass\" size=20></label><br>
</td></tr>\n" );
# Skin setting
#
$wgOut->addHTML( "<tr><td valign=top nowrap><b>$sk:</b><br>\n" );
# Only show members of $wgValidSkinNames rather than
# $skinNames (skins is all skin names from Language.php)
foreach ($wgValidSkinNames as $skinkey => $skinname ) {
if ( $skinkey == $wpSkin ) {
$checked = ' checked';
} else {
$checked = "";
}
$wgOut->addHTML( "<label><input type=radio name=\"wpSkin\"
value=\"$skinkey\"$checked> {$skinNames[$skinkey]}</label><br>\n" );
}
# Various checkbox options
#
if ( $wgUseDynamicDates ) {
$wgOut->addHTML( "</td><td rowspan=3 valign=top nowrap>\n" );
} else {
$wgOut->addHTML( "</td><td rowspan=2 valign=top nowrap>\n" );
}
$wgOut->addHTML("<table border=0>");
foreach ( $togs as $tname => $ttext ) {
if ( 1 == $wgUser->getOption( $tname ) ) {
$checked = " checked";
} else {
$checked = "";
}
$wgOut->addHTML( "<tr valign=\"top\"><td><input type=checkbox value=\"1\" "
. "id=\"$tname\" name=\"wpOp$tname\"$checked></td><td><label for=\"$tname\">$ttext</label></td></tr>\n" );
}
$wgOut->addHTML( "</table></td>" );
# Math setting
#
$wgOut->addHTML( "<tr><td valign=top nowrap><b>$math:</b><br>\n" );
for ( $i = 0; $i < count( $mathopts ); ++$i ) {
if ( $i == $wpMath ) { $checked = " checked"; }
else { $checked = ""; }
$wgOut->addHTML( "<label><input type=radio name=\"wpMath\"
value=\"$i\"$checked> {$mathopts[$i]}</label><br>\n" );
}
$wgOut->addHTML( "</td></tr>" );
# Date format
#
if ( $wgUseDynamicDates ) {
$wgOut->addHTML( "<tr><td valign=top nowrap><b>$dateFormat:</b><br>" );
for ( $i = 0; $i < count( $dateopts ); ++$i) {
if ( $i == $wpDate ) {
$wgOut->addHTML("<table border=0>");
foreach ( $togs as $tname => $ttext ) {
if ( 1 == $wgUser->getOption( $tname ) ) {
$checked = " checked";
} else {
$checked = "";
}
$wgOut->addHTML( "<label><input type=radio name=\"wpDate\" ".
"value=\"$i\"$checked> {$dateopts[$i]}</label><br>\n" );
}
$wgOut->addHTML( "<tr valign=\"top\"><td><input type=checkbox value=\"1\" "
. "id=\"$tname\" name=\"wpOp$tname\"$checked></td><td><label for=\"$tname\">$ttext</label></td></tr>\n" );
}
$wgOut->addHTML( "</td></tr>");
$wgOut->addHTML( "</table></td>" );
# Math setting
#
$wgOut->addHTML( "<tr><td valign=top nowrap><b>$math:</b><br>\n" );
for ( $i = 0; $i < count( $mathopts ); ++$i ) {
if ( $i == $this->mMath ) { $checked = " checked"; }
else { $checked = ""; }
$wgOut->addHTML( "<label><input type=radio name=\"wpMath\"
value=\"$i\"$checked> {$mathopts[$i]}</label><br>\n" );
}
$wgOut->addHTML( "</td></tr>" );
# Date format
#
if ( $wgUseDynamicDates ) {
$wgOut->addHTML( "<tr><td valign=top nowrap><b>$dateFormat:</b><br>" );
for ( $i = 0; $i < count( $dateopts ); ++$i) {
if ( $i == $this->mDate ) {
$checked = " checked";
} else {
$checked = "";
}
$wgOut->addHTML( "<label><input type=radio name=\"wpDate\" ".
"value=\"$i\"$checked> {$dateopts[$i]}</label><br>\n" );
}
$wgOut->addHTML( "</td></tr>");
}
# Textbox rows, cols
#
$nowlocal = $wgLang->time( $now = wfTimestampNow(), true );
$nowserver = $wgLang->time( $now, false );
$wgOut->addHTML( "<td valign=top nowrap><b>$tbs:</b><br>
<label>$tbr: <input type=text name=\"wpRows\" value=\"{$this->mRows}\" size=6></label><br>
<label>$tbc: <input type=text name=\"wpCols\" value=\"{$this->mCols}\" size=6></label><br><br>
<b>$tzServerTime:</b> $nowserver<br />
<b>$ltz:</b> $nowlocal<br />
<label>$tzo*: <input type=text name=\"wpHourDiff\" value=\"{$this->mHourDiff}\" size=6></label><br />
<input type=\"button\" value=\"$tzGuess\" onClick=\"javascript:guessTimezone()\" />
</td>" );
# Email, etc.
#
$this->mUserEmail = wfEscapeHTML( $this->mUserEmail );
$this->mNick = wfEscapeHTML( $this->mNick );
if ( $this->mEmailFlag ) { $emfc = "checked"; }
else { $emfc = ""; }
$ps = $this->namespacesCheckboxes();
$wgOut->addHTML( "<td valign=top nowrap>
<label>$yem: <input type=text name=\"wpUserEmail\" value=\"{$this->mUserEmail}\" size=20></label><br>
<label><input type=checkbox $emfc value=\"1\" name=\"wpEmailFlag\"> $emf</label><br>
<label>$ynn: <input type=text name=\"wpNick\" value=\"{$this->mNick}\" size=12></label><br>
<label>$rcc: <input type=text name=\"wpRecent\" value=\"$this->mRecent\" size=6></label><br>
<label>$stt: <input type=text name=\"wpStubs\" value=\"$this->mStubs\" size=6></label><br>
<strong>{$srh}:</strong><br>
<label>$rpp: <input type=text name=\"wpSearch\" value=\"$this->mSearch\" size=6></label><br>
<label>$scl: <input type=text name=\"wpSearchLines\" value=\"$this->mSearchLines\" size=6></label><br>
<label>$scc: <input type=text name=\"wpSearchChars\" value=\"$this->mSearchChars\" size=6></label></td>
</tr><tr>
<td colspan=2>
<b>$dsn</b><br>
$ps
</td>
</tr><tr>
<td align=center><input type=submit name=\"wpSaveprefs\" value=\"$svp\"></td>
<td align=center><input type=submit name=\"wpReset\" value=\"$rsp\"></td>
</tr></table>* {$tzt} </form>\n" );
}
# Textbox rows, cols
#
$nowlocal = $wgLang->time( $now = wfTimestampNow(), true );
$nowserver = $wgLang->time( $now, false );
$wgOut->addHTML( "<td valign=top nowrap><b>$tbs:</b><br>
<label>$tbr: <input type=text name=\"wpRows\" value=\"{$wpRows}\" size=6></label><br>
<label>$tbc: <input type=text name=\"wpCols\" value=\"{$wpCols}\" size=6></label><br><br>
<b>$tzServerTime:</b> $nowserver<br />
<b>$ltz:</b> $nowlocal<br />
<label>$tzo*: <input type=text name=\"wpHourDiff\" value=\"{$wpHourDiff}\" size=6></label><br />
<input type=\"button\" value=\"$tzGuess\" onClick=\"javascript:guessTimezone()\" />
</td>" );
# Email, etc.
#
$wpUserEmail = wfEscapeHTML( $wpUserEmail );
$wpNick = wfEscapeHTML( $wpNick );
if ( $wpEmailFlag ) { $emfc = "checked"; }
else { $emfc = ""; }
$ps = namespacesCheckboxes();
$wgOut->addHTML( "<td valign=top nowrap>
<label>$yem: <input type=text name=\"wpUserEmail\" value=\"{$wpUserEmail}\" size=20></label><br>
<label><input type=checkbox $emfc value=\"1\" name=\"wpEmailFlag\"> $emf</label><br>
<label>$ynn: <input type=text name=\"wpNick\" value=\"{$wpNick}\" size=12></label><br>
<label>$rcc: <input type=text name=\"wpRecent\" value=\"$wpRecent\" size=6></label><br>
<label>$stt: <input type=text name=\"wpStubs\" value=\"$wpStubs\" size=6></label><br>
<strong>{$srh}:</strong><br>
<label>$rpp: <input type=text name=\"wpSearch\" value=\"$wpSearch\" size=6></label><br>
<label>$scl: <input type=text name=\"wpSearchLines\" value=\"$wpSearchLines\" size=6></label><br>
<label>$scc: <input type=text name=\"wpSearchChars\" value=\"$wpSearchChars\" size=6></label></td>
</tr><tr>
<td colspan=2>
<b>$dsn</b><br>
$ps
</td>
</tr><tr>
<td align=center><input type=submit name=\"wpSaveprefs\" value=\"$svp\"></td>
<td align=center><input type=submit name=\"wpReset\" value=\"$rsp\"></td>
</tr></table>* {$tzt} </form>\n" );
}
?>

View file

@ -6,12 +6,24 @@ function wfSpecialRecentchanges( $par )
{
global $wgUser, $wgOut, $wgLang, $wgTitle, $wgMemc, $wgDBname;
global $wgRequest, $wgSitename, $wgLanguageCode;
global $days, $hideminor, $from, $hidebots, $hideliu; # From query string
$fname = "wfSpecialRecentchanges";
# Get query parameters
$feedFormat = $wgRequest->getVal( "feed" );
$feeding = ( $feedFormat == "rss" );
$defaultDays = $wgUser->getOption( 'rcdays' );
if ( !$defaultDays ) {
$defaultDays = 3;
}
$days = $wgRequest->getInt( 'days', $defaultDays );
$hideminor = $wgRequest->getBool( 'hideminor', $wgUser->getOption( 'hideminor' ) ) ? 1 : 0;
$from = $wgRequest->getText( 'from' );
$hidebots = $wgRequest->getBool( 'hidebots', true ) ? 1 : 0;
$hideliu = $wgRequest->getBool( 'hideliu', false ) ? 1 : 0;
# Get query parameters from path
if( $par ) {
$bits = preg_split( '/\s*,\s*/', trim( $par ) );
if( in_array( "hidebots", $bits ) ) $hidebots = 1;
@ -41,12 +53,7 @@ function wfSpecialRecentchanges( $par )
}
$wgOut->addWikiText( $rctext );
if ( ! $days ) {
$days = $wgUser->getOption( "rcdays" );
if ( ! $days ) { $days = 3; }
}
$days = (int)$days;
list( $limit, $offset ) = wfCheckLimits( 100, "rclimit" );
$now = wfTimestampNow();
$cutoff_unixtime = time() - ( $days * 86400 );
@ -61,27 +68,16 @@ function wfSpecialRecentchanges( $par )
$sk = $wgUser->getSkin();
$showhide = array( wfMsg( "show" ), wfMsg( "hide" ));
if ( ! isset( $hideminor ) ) {
$hideminor = $wgUser->getOption( "hideminor" );
}
$hideminor = ($hideminor ? 1 : 0);
if ( $hideminor ) {
$hidem = "AND rc_minor=0";
} else {
$hidem = "";
}
if ( !isset( $hidebots ) ) {
$hidebots = 1;
}
if( $hidebots ) {
$hidem .= " AND rc_bot=0";
}
$hidebots = ($hidebots ? 1 : 0);
if ( !isset( $hideliu ) ) {
$hideliu = 0;
}
if ( $hideliu ) {
$hidem .= " AND rc_user=0";
}

View file

@ -2,123 +2,156 @@
function wfSpecialUndelete( $par )
{
global $wgLang, $wgUser, $wgOut, $action, $target, $timestamp, $restore;
if( $par != "" ) $target = $par;
if( isset($target ) ) {
$t = Title::newFromURL( $target );
$title = $t->mDbkeyform;
$namespace = $t->mNamespace;
if( isset( $timestamp ) ) {
return doUndeleteShowRevision( $namespace, $title, $timestamp );
}
if( isset( $action ) and isset( $restore) and $action == "submit" ) {
return doUndeleteArticle( $namespace, $title );
}
return doUndeleteShowHistory( $namespace, $title );
}
# List undeletable articles
$sql = "SELECT ar_namespace,ar_title, COUNT(*) AS count FROM archive GROUP BY ar_namespace,ar_title ORDER BY ar_namespace,ar_title";
$res = wfQuery( $sql, DB_READ );
$wgOut->setPagetitle( wfMsg( "undeletepage" ) );
$wgOut->addWikiText( wfMsg( "undeletepagetext" ) );
global $wgRequest;
$special = $wgLang->getNsText( Namespace::getSpecial() );
$sk = $wgUser->getSkin();
$wgOut->addHTML( "<ul>\n" );
while ($row = wfFetchObject( $res )) {
$n = ($row->ar_namespace ?
($wgLang->getNsText( $row->ar_namespace ) . ":") : "").
$row->ar_title;
$wgOut->addHTML( "<li>" .
$sk->makeKnownLink( $wgLang->specialPage( "Undelete" ),
$n, "target=" . urlencode($n) ) . " " .
wfMsg( "undeleterevisions", $row->count ) );
}
$wgOut->addHTML( "</ul>\n" );
return $ret;
$form = new UndeleteForm( $wgRequest, $par );
$form->execute();
}
/* private */ function doUndeleteShowRevision( $namespace, $title, $timestamp ) {
global $wgLang, $wgUser, $wgOut, $action, $target, $timestamp, $restore;
if(!preg_match("/[0-9]{14}/",$timestamp)) return 0;
$sql = "SELECT ar_text,ar_flags FROM archive WHERE ar_namespace={$namespace} AND ar_title=\"{$title}\" AND ar_timestamp={$timestamp}";
$ret = wfQuery( $sql, DB_READ );
$row = wfFetchObject( $ret );
$wgOut->setPagetitle( wfMsg( "undeletepage" ) );
$wgOut->addWikiText( "(" . wfMsg( "undeleterevision", $wgLang->date($timestamp, true) )
. ")\n<hr>\n" . Article::getRevisionText( $row, "ar_" ) );
class UndeleteForm {
var $mAction, $mTarget, $mTimestamp, $mRestore, $mTargetObj;
return 0;
}
function UndeleteForm( &$request, $par = "" ) {
$this->mAction = $request->getText( 'action' );
$this->mTarget = $request->getText( 'target' );
$this->mTimestamp = $request->getText( 'timestamp' );
$this->mRestore = $request->getCheck( 'restore' );
if( $par != "" ) {
$this->mTarget = $par;
}
if ( $this->mTarget !== "" ) {
$this->mTargetObj = Title::newFromURL( $this->mTarget );
} else {
$this->mTargetObj = NULL;
}
}
/* private */ function doUndeleteShowHistory( $namespace, $title ) {
global $wgLang, $wgUser, $wgOut, $action, $target, $timestamp, $restore;
$sk = $wgUser->getSkin();
$wgOut->setPagetitle( wfMsg( "undeletepage" ) );
# Get text of first revision
$sql = "SELECT ar_text FROM archive WHERE ar_namespace={$namespace} AND ar_title=\"{$title}\"
ORDER BY ar_timestamp DESC LIMIT 1";
$ret = wfQuery( $sql, DB_READ );
function execute() {
if( !is_null( $this->mTargetObj ) ) {
$title = $this->mTargetObj->mDbkeyform;
$namespace = $this->mTargetObj->mNamespace;
if( $this->mTimestamp !== "" ) {
return $this->showRevision( $namespace, $title, $this->mTimestamp );
}
if( $this->mRestore and $this->mAction == "submit" ) {
return $this->undelete( $namespace, $title );
}
return $this->showHistory( $namespace, $title );
} else {
return $this->showList();
}
}
if( wfNumRows( $ret ) == 0 ) {
$wgOut->addWikiText( wfMsg( "nohistory" ) );
/* private */ function showList() {
global $wgLang, $wgUser, $wgOut;
$fname = "UndeleteForm::showList";
# List undeletable articles
$sql = "SELECT ar_namespace,ar_title, COUNT(*) AS count FROM archive " .
"GROUP BY ar_namespace,ar_title ORDER BY ar_namespace,ar_title";
$res = wfQuery( $sql, DB_READ, $fname );
$wgOut->setPagetitle( wfMsg( "undeletepage" ) );
$wgOut->addWikiText( wfMsg( "undeletepagetext" ) );
$special = $wgLang->getNsText( Namespace::getSpecial() );
$sk = $wgUser->getSkin();
$wgOut->addHTML( "<ul>\n" );
while ($row = wfFetchObject( $res )) {
$n = ($row->ar_namespace ?
($wgLang->getNsText( $row->ar_namespace ) . ":") : "").
$row->ar_title;
$wgOut->addHTML( "<li>" .
$sk->makeKnownLink( $wgLang->specialPage( "Undelete" ),
$n, "target=" . urlencode($n) ) . " " .
wfMsg( "undeleterevisions", $row->count ) );
}
$wgOut->addHTML( "</ul>\n" );
return 0;
}
$row = wfFetchObject( $ret );
$wgOut->addWikiText( wfMsg( "undeletehistory" ) . "\n<hr>\n" . $row->ar_text );
/* private */ function showRevision( $namespace, $title, $timestamp ) {
global $wgLang, $wgUser, $wgOut;
$fname = "UndeleteForm::showRevision";
# Get remaining revisions
$sql = "SELECT ar_minor_edit,ar_timestamp,ar_user,ar_user_text,ar_comment
FROM archive WHERE ar_namespace={$namespace} AND ar_title=\"{$title}\"
ORDER BY ar_timestamp DESC";
$ret = wfQuery( $sql, DB_READ );
# Ditch first row
$row = wfFetchObject( $ret );
if(!preg_match("/[0-9]{14}/",$timestamp)) return 0;
$sql = "SELECT ar_text,ar_flags FROM archive ".
"WHERE ar_namespace={$namespace} AND ar_title=\"{$title}\" AND ar_timestamp={$timestamp}";
$ret = wfQuery( $sql, DB_READ, $fname );
$row = wfFetchObject( $ret );
$wgOut->setPagetitle( wfMsg( "undeletepage" ) );
$wgOut->addWikiText( "(" . wfMsg( "undeleterevision", $wgLang->date($timestamp, true) )
. ")\n<hr>\n" . Article::getRevisionText( $row, "ar_" ) );
$titleObj = Title::makeTitle( NS_SPECIAL, "Undelete" );
$action = $titleObj->escapeLocalURL( "action=submit" );
$wgOut->addHTML("<p>
<form id=\"undelete\" method=\"post\" action=\"{$action}\">
<input type=hidden name=\"target\" value=\"{$target}\">
<input type=submit name=\"restore\" value=\"".wfMsg("undeletebtn")."\">
</form>");
return 0;
}
$log = wfGetSQL("cur", "cur_text", "cur_namespace=4 AND cur_title=\"".wfMsg("dellogpage")."\"" );
if(preg_match("/^(.*".
preg_quote( ($namespace ? ($wgLang->getNsText($namespace) . ":") : "")
. str_replace("_", " ", $title), "/" ).".*)$/m", $log, $m)) {
$wgOut->addWikiText( $m[1] );
}
$special = $wgLang->getNsText( Namespace::getSpecial() );
$wgOut->addHTML("<ul>");
while( $row = wfFetchObject( $ret ) ) {
$wgOut->addHTML( "<li>" .
$sk->makeKnownLink( $wgLang->specialPage( "Undelete" ),
$wgLang->timeanddate( $row->ar_timestamp, true ),
"target=" . urlencode($target) . "&timestamp={$row->ar_timestamp}" ) . " " .
". . {$row->ar_user_text}" .
" <i>(" . htmlspecialchars($row->ar_comment) . "</i>)\n");
/* private */ function showHistory( $namespace, $title ) {
global $wgLang, $wgUser, $wgOut;
$sk = $wgUser->getSkin();
$wgOut->setPagetitle( wfMsg( "undeletepage" ) );
# Get text of first revision
$sql = "SELECT ar_text FROM archive WHERE ar_namespace={$namespace} AND ar_title=\"{$title}\"
ORDER BY ar_timestamp DESC LIMIT 1";
$ret = wfQuery( $sql, DB_READ );
}
$wgOut->addHTML("</ul>");
return 0;
}
if( wfNumRows( $ret ) == 0 ) {
$wgOut->addWikiText( wfMsg( "nohistory" ) );
return 0;
}
$row = wfFetchObject( $ret );
$wgOut->addWikiText( wfMsg( "undeletehistory" ) . "\n<hr>\n" . $row->ar_text );
/* private */ function doUndeleteArticle( $namespace, $title )
# Get remaining revisions
$sql = "SELECT ar_minor_edit,ar_timestamp,ar_user,ar_user_text,ar_comment
FROM archive WHERE ar_namespace={$namespace} AND ar_title=\"{$title}\"
ORDER BY ar_timestamp DESC";
$ret = wfQuery( $sql, DB_READ );
# Ditch first row
$row = wfFetchObject( $ret );
$titleObj = Title::makeTitle( NS_SPECIAL, "Undelete" );
$action = $titleObj->escapeLocalURL( "action=submit" );
$encTarget = htmlspecialchars( $this->mTarget );
$wgOut->addHTML("<p>
<form id=\"undelete\" method=\"post\" action=\"{$action}\">
<input type=hidden name=\"target\" value=\"{$encTarget}\">
<input type=submit name=\"restore\" value=\"".wfMsg("undeletebtn")."\">
</form>");
$log = wfGetSQL("cur", "cur_text", "cur_namespace=4 AND cur_title=\"".wfMsg("dellogpage")."\"" );
if(preg_match("/^(.*".
preg_quote( ($namespace ? ($wgLang->getNsText($namespace) . ":") : "")
. str_replace("_", " ", $title), "/" ).".*)$/m", $log, $m)) {
$wgOut->addWikiText( $m[1] );
}
$special = $wgLang->getNsText( Namespace::getSpecial() );
$wgOut->addHTML("<ul>");
while( $row = wfFetchObject( $ret ) ) {
$wgOut->addHTML( "<li>" .
$sk->makeKnownLink( $wgLang->specialPage( "Undelete" ),
$wgLang->timeanddate( $row->ar_timestamp, true ),
"target=" . urlencode($this->mTarget) . "&timestamp={$row->ar_timestamp}" ) . " " .
". . {$row->ar_user_text}" .
" <i>(" . htmlspecialchars($row->ar_comment) . "</i>)\n");
}
$wgOut->addHTML("</ul>");
return 0;
}
/* private */ function undelete( $namespace, $title )
{
global $wgUser, $wgOut, $wgLang, $target, $wgDeferredUpdateList;
global $wgUser, $wgOut, $wgLang, $wgDeferredUpdateList;
global $wgUseSquid, $wgInternalServer;
$fname = "doUndeleteArticle";
@ -150,7 +183,7 @@ function wfSpecialUndelete( $par )
"ar_user,ar_user_text,ar_timestamp,99999999999999-ar_timestamp,ar_minor_edit,{$redir},RAND(),'{$now}' FROM archive " .
"WHERE ar_namespace={$namespace} AND ar_title='{$t}' AND ar_timestamp={$max}";
wfQuery( $sql, DB_WRITE, $fname );
$newid = wfInsertId();
$newid = wfInsertId();
$oldones = "AND ar_timestamp<{$max}";
} else {
# If already exists, put history entirely into old table
@ -172,13 +205,12 @@ function wfSpecialUndelete( $par )
"FROM archive WHERE ar_namespace={$namespace} AND ar_title='{$t}' {$oldones}";
wfQuery( $sql, DB_WRITE, $fname );
# Finally, clean up the link tables
# Finally, clean up the link tables
if( $newid ) {
# Create a dummy OutputPage to update the outgoing links
# This works at the moment due to good luck. It may stop working in the
# future. Damn globals.
$dummyOut = new OutputPage();
$to = Title::newFromDBKey( $target );
$res = wfQuery( "SELECT cur_text FROM cur WHERE cur_id={$newid} " .
"AND cur_namespace={$namespace}", DB_READ, $fname );
$row = wfFetchObject( $res );
@ -186,10 +218,10 @@ function wfSpecialUndelete( $par )
$dummyOut->addWikiText( $text );
wfFreeResult( $res );
$u = new LinksUpdate( $newid, $to->getPrefixedDBkey() );
$u = new LinksUpdate( $newid, $this->mTargetObj->getPrefixedDBkey() );
array_push( $wgDeferredUpdateList, $u );
Article::onArticleCreate( $to );
Article::onArticleCreate( $this->mTargetObj );
#TODO: SearchUpdate, etc.
}
@ -202,9 +234,10 @@ function wfSpecialUndelete( $par )
# Touch the log?
$log = new LogPage( wfMsg( "dellogpage" ), wfMsg( "dellogpagetext" ) );
$log->addEntry( wfMsg( "undeletedarticle", $target ), "" );
$log->addEntry( wfMsg( "undeletedarticle", $this->mTarget ), "" );
$wgOut->addWikiText( wfMsg( "undeletedtext", $target ) );
$wgOut->addWikiText( wfMsg( "undeletedtext", $this->mTarget ) );
return 0;
}
}
?>

View file

@ -10,423 +10,439 @@ function wfSpecialUserlogin()
User::SetupSession();
}
$fields = array( "wpName", "wpPassword", "wpName",
"wpPassword", "wpRetype" );
# FIXME: UGLY HACK
foreach( $fields as $x ) {
$_REQUEST[$x] = $wgRequest->getText( $x );
}
$form = new LoginForm( $wgRequest );
$form->execute();
}
# When switching accounts, it sucks to get automatically logged out
global $wgLang;
if( $wgRequest->getVal( 'returnto' ) == $wgLang->specialPage( "Userlogout" ) ) {
$_REQUEST['returnto'] = "";
}
class LoginForm {
var $mName, $mPassword, $mRetype, $mReturnto, $mCookieCheck, $mPosted;
var $mAction, $mCreateaccount, $mCreateaccountMail, $mMailmypassword;
var $mLoginattempt, $mRemember, $mEmail;
$wpCookieCheck = $wgRequest->getVal( "wpCookieCheck" );
function LoginForm( &$request ) {
global $wgLang;
if ( isset( $wpCookieCheck ) ) {
onCookieRedirectCheck( $wpCookieCheck );
} else if( $wgRequest->wasPosted() ) {
if( $wgRequest->getCheck( 'wpCreateaccount' ) ) {
return addNewAccount();
} else if ( $wgRequest->getCheck( 'wpCreateaccountMail' ) ) {
return addNewAccountMailPassword();
} else if ( $wgRequest->getCheck( 'wpMailmypassword' ) ) {
return mailPassword();
} else if ( "submit" == $wgRequest->getVal( 'action' ) || $wgRequest->getCheck( 'wpLoginattempt' ) ) {
return processLogin();
$this->mName = $request->getText( 'wpName' );
$this->mPassword = $request->getText( 'wpPassword' );
$this->mRetype = $request->getText( 'wpRetype' );
$this->mReturnto = $request->getText( 'returnto' );
$this->mCookieCheck = $request->getVal( "wpCookieCheck" );
$this->mPosted = $request->wasPosted();
$this->mCreateaccount = $request->getCheck( 'wpCreateaccount' );
$this->mCreateaccountMail = $request->getCheck( 'wpCreateaccountMail' );
$this->mMailmypassword = $request->getCheck( 'wpMailmypassword' );
$this->mLoginattempt = $request->getCheck( 'wpLoginattempt' );
$this->mAction = $request->getVal( 'action' );
$this->mRemember = $request->getCheck( 'wpRemember' );
$this->mEmail = $request->getText( 'wpEmail' );
# When switching accounts, it sucks to get automatically logged out
if( $this->mReturnto == $wgLang->specialPage( "Userlogout" ) ) {
$this->mReturnto = "";
}
}
mainLoginForm( "" );
}
/* private */ function addNewAccountMailPassword()
{
global $wgOut;
if ("" == $_REQUEST['wpEmail']) {
mainLoginForm( wfMsg( "noemail", $_REQUEST['wpName'] ) );
return;
function execute() {
if ( !is_null( $this->mCookieCheck ) ) {
$this->onCookieRedirectCheck( $this->mCookieCheck );
} else if( $this->mPosted ) {
if( $this->mCreateaccount ) {
return $this->addNewAccount();
} else if ( $this->mCreateaccountMail ) {
return $this->addNewAccountMailPassword();
} else if ( $this->mMailmypassword ) {
return $this->mailPassword();
} else if ( ( "submit" == $this->mAction ) || $this->mLoginattempt ) {
return $this->processLogin();
}
}
$this->mainLoginForm( "" );
}
$u = addNewaccountInternal();
if ($u == NULL) {
return;
}
$u->saveSettings();
if (mailPasswordInternal($u) == NULL) {
return;
}
$wgOut->setPageTitle( wfMsg( "accmailtitle" ) );
$wgOut->setRobotpolicy( "noindex,nofollow" );
$wgOut->setArticleRelated( false );
$wgOut->addWikiText( wfMsg( "accmailtext", $u->getName(), $u->getEmail() ) );
$wgOut->returnToMain( false );
$u = 0;
}
/* private */ function addNewAccount()
{
global $wgUser, $wgOut;
global $wgDeferredUpdateList;
$u = addNewAccountInternal();
if ($u == NULL) {
return;
}
$wgUser = $u;
$wgUser->setCookies();
$up = new UserUpdate();
array_push( $wgDeferredUpdateList, $up );
if( hasSessionCookie() ) {
return successfulLogin( wfMsg( "welcomecreation", $wgUser->getName() ) );
} else {
return cookieRedirectCheck( "new" );
}
}
/* private */ function addNewAccountInternal()
{
global $wgUser, $wgOut;
global $wgMaxNameChars;
global $wgRequest;
if (!$wgUser->isAllowedToCreateAccount()) {
userNotPrivilegedMessage();
return;
}
if ( 0 != strcmp( $_REQUEST['wpPassword'], $_REQUEST['wpRetype'] ) ) {
mainLoginForm( wfMsg( "badretype" ) );
return;
}
$name = trim( $_REQUEST['wpName'] );
if ( ( "" == $name ) ||
preg_match( "/\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}/", $name ) ||
(strpos( $name, "/" ) !== false) ||
(strlen( $name ) > $wgMaxNameChars) )
/* private */ function addNewAccountMailPassword()
{
mainLoginForm( wfMsg( "noname" ) );
return;
}
if ( wfReadOnly() ) {
$wgOut->readOnlyPage();
return;
}
$u = User::newFromName( $name );
if ( 0 != $u->idForName() ) {
mainLoginForm( wfMsg( "userexists" ) );
return;
}
$u->addToDatabase();
$u->setPassword( $_REQUEST['wpPassword'] );
$u->setEmail( $_REQUEST['wpEmail'] );
if ( $wgRequest->getCheck( 'wpRemember' ) ) { $r = 1; }
else { $r = 0; }
$u->setOption( "rememberpassword", $r );
return $u;
}
/* private */ function processLogin()
{
global $wgUser;
global $wgDeferredUpdateList;
global $wgRequest;
if ( "" == $_REQUEST['wpName'] ) {
mainLoginForm( wfMsg( "noname" ) );
return;
}
$u = User::newFromName( $_REQUEST['wpName'] );
$id = $u->idForName();
if ( 0 == $id ) {
mainLoginForm( wfMsg( "nosuchuser", $u->getName() ) );
return;
}
$u->setId( $id );
$u->loadFromDatabase();
$ep = $u->encryptPassword( $_REQUEST['wpPassword'] );
if ( 0 != strcmp( $ep, $u->getPassword() ) ) {
if ( 0 != strcmp( $ep, $u->getNewpassword() ) ) {
mainLoginForm( wfMsg( "wrongpassword" ) );
global $wgOut;
if ("" == $this->mEmail) {
$this->mainLoginForm( wfMsg( "noemail", $this->mName ) );
return;
}
$u = $this->addNewaccountInternal();
if ($u == NULL) {
return;
}
$u->saveSettings();
$error = $this->mailPasswordInternal($u);
$wgOut->setPageTitle( wfMsg( "accmailtitle" ) );
$wgOut->setRobotpolicy( "noindex,nofollow" );
$wgOut->setArticleRelated( false );
if ( $error === "" ) {
$wgOut->addWikiText( wfMsg( "accmailtext", $u->getName(), $u->getEmail() ) );
$wgOut->returnToMain( false );
} else {
$this->mainLoginForm( wfMsg( "mailerror", $error ) );
}
$u = 0;
}
# We've verified now, update the real record
#
if ( $wgRequest->getCheck( 'wpRemember' ) ) {
$r = 1;
$u->setCookiePassword( $wgRequest->getText( 'wpPassword' ) );
} else {
$r = 0;
}
$u->setOption( "rememberpassword", $r );
$wgUser = $u;
$wgUser->setCookies();
/* private */ function addNewAccount()
{
global $wgUser, $wgOut;
global $wgDeferredUpdateList;
$up = new UserUpdate();
array_push( $wgDeferredUpdateList, $up );
$u = $this->addNewAccountInternal();
if( hasSessionCookie() ) {
return successfulLogin( wfMsg( "loginsuccess", $wgUser->getName() ) );
} else {
return cookieRedirectCheck( "login" );
}
}
if ($u == NULL) {
return;
}
/* private */ function mailPassword()
{
global $wgUser, $wgDeferredUpdateList, $wgOutputEncoding;
global $wgCookiePath, $wgCookieDomain, $wgDBname;
$wgUser = $u;
$wgUser->setCookies();
if ( "" == $_REQUEST['wpName'] ) {
mainLoginForm( wfMsg( "noname" ) );
return;
}
$u = User::newFromName( $_REQUEST['wpName'] );
$id = $u->idForName();
if ( 0 == $id ) {
mainLoginForm( wfMsg( "nosuchuser", $u->getName() ) );
return;
}
$u->setId( $id );
$u->loadFromDatabase();
$up = new UserUpdate();
array_push( $wgDeferredUpdateList, $up );
if (mailPasswordInternal($u) == NULL) {
return;
if( $this->hasSessionCookie() ) {
return $this->successfulLogin( wfMsg( "welcomecreation", $wgUser->getName() ) );
} else {
return $this->cookieRedirectCheck( "new" );
}
}
mainLoginForm( wfMsg( "passwordsent", $u->getName() ) );
}
/* private */ function addNewAccountInternal()
{
global $wgUser, $wgOut;
global $wgMaxNameChars;
/* private */ function mailPasswordInternal( $u )
{
global $wgDeferredUpdateList, $wgOutputEncoding;
global $wgPasswordSender, $wgDBname, $wgIP;
if (!$wgUser->isAllowedToCreateAccount()) {
$this->userNotPrivilegedMessage();
return;
}
if ( "" == $u->getEmail() ) {
mainLoginForm( wfMsg( "noemail", $u->getName() ) );
return;
if ( 0 != strcmp( $this->mPassword, $this->mRetype ) ) {
$this->mainLoginForm( wfMsg( "badretype" ) );
return;
}
$name = trim( $this->mName );
if ( ( "" == $name ) ||
preg_match( "/\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}/", $name ) ||
(strpos( $name, "/" ) !== false) ||
(strlen( $name ) > $wgMaxNameChars) )
{
$this->mainLoginForm( wfMsg( "noname" ) );
return;
}
if ( wfReadOnly() ) {
$wgOut->readOnlyPage();
return;
}
$u = User::newFromName( $name );
if ( 0 != $u->idForName() ) {
$this->mainLoginForm( wfMsg( "userexists" ) );
return;
}
$u->addToDatabase();
$u->setPassword( $this->mPassword );
$u->setEmail( $this->mEmail );
if ( $this->mRemember ) { $r = 1; }
else { $r = 0; }
$u->setOption( "rememberpassword", $r );
return $u;
}
$np = User::randomPassword();
$u->setNewpassword( $np );
setcookie( "{$wgDBname}Password", "", time() - 3600, $wgCookiePath, $wgCookieDomain );
$u->saveSettings();
$ip = $wgIP;
if ( "" == $ip ) { $ip = "(Unknown)"; }
$m = wfMsg( "passwordremindertext", $ip, $u->getName(), $np );
/* private */ function processLogin()
{
global $wgUser;
global $wgDeferredUpdateList;
userMailer( $u->getEmail(), $wgPasswordSender, wfMsg( "passwordremindertitle" ), $m );
if ( "" == $this->mName ) {
$this->mainLoginForm( wfMsg( "noname" ) );
return;
}
$u = User::newFromName( $this->mName );
$id = $u->idForName();
if ( 0 == $id ) {
$this->mainLoginForm( wfMsg( "nosuchuser", $u->getName() ) );
return;
}
$u->setId( $id );
$u->loadFromDatabase();
$ep = $u->encryptPassword( $this->mPassword );
if ( 0 != strcmp( $ep, $u->getPassword() ) ) {
if ( 0 != strcmp( $ep, $u->getNewpassword() ) ) {
$this->mainLoginForm( wfMsg( "wrongpassword" ) );
return;
}
}
# We've verified now, update the real record
#
if ( $this->mRemember ) {
$r = 1;
$u->setCookiePassword( $this->mPassword );
} else {
$r = 0;
}
$u->setOption( "rememberpassword", $r );
$wgUser = $u;
$wgUser->setCookies();
$up = new UserUpdate();
array_push( $wgDeferredUpdateList, $up );
if( $this->hasSessionCookie() ) {
return $this->successfulLogin( wfMsg( "loginsuccess", $wgUser->getName() ) );
} else {
return $this->cookieRedirectCheck( "login" );
}
}
/* private */ function mailPassword()
{
global $wgUser, $wgDeferredUpdateList, $wgOutputEncoding;
global $wgCookiePath, $wgCookieDomain, $wgDBname;
if ( "" == $this->mName ) {
$this->mainLoginForm( wfMsg( "noname" ) );
return;
}
$u = User::newFromName( $this->mName );
$id = $u->idForName();
if ( 0 == $id ) {
$this->mainLoginForm( wfMsg( "nosuchuser", $u->getName() ) );
return;
}
$u->setId( $id );
$u->loadFromDatabase();
$error = $this->mailPasswordInternal( $u );
if ($error === "") {
$this->mainLoginForm( wfMsg( "passwordsent", $u->getName() ) );
} else {
$this->mainLoginForm( wfMsg( "mailerror", $error ) );
}
}
/* private */ function mailPasswordInternal( $u )
{
global $wgDeferredUpdateList, $wgOutputEncoding;
global $wgPasswordSender, $wgDBname, $wgIP;
global $wgCookiePath, $wgCookieDomain;
if ( "" == $u->getEmail() ) {
$this->mainLoginForm( wfMsg( "noemail", $u->getName() ) );
return;
}
$np = User::randomPassword();
$u->setNewpassword( $np );
setcookie( "{$wgDBname}Password", "", time() - 3600, $wgCookiePath, $wgCookieDomain );
$u->saveSettings();
$ip = $wgIP;
if ( "" == $ip ) { $ip = "(Unknown)"; }
$m = wfMsg( "passwordremindertext", $ip, $u->getName(), $np );
$error = userMailer( $u->getEmail(), $wgPasswordSender, wfMsg( "passwordremindertitle" ), $m );
return $error;
}
/* private */ function successfulLogin( $msg )
{
global $wgUser;
global $wgDeferredUpdateList;
global $wgOut;
$wgOut->setPageTitle( wfMsg( "loginsuccesstitle" ) );
$wgOut->setRobotpolicy( "noindex,nofollow" );
$wgOut->setArticleRelated( false );
$wgOut->addHTML( $msg . "\n<p>" );
$wgOut->returnToMain();
}
function userNotPrivilegedMessage()
{
global $wgOut, $wgUser, $wgLang;
$wgOut->setPageTitle( wfMsg( "whitelistacctitle" ) );
$wgOut->setRobotpolicy( "noindex,nofollow" );
$wgOut->setArticleRelated( false );
$wgOut->addWikiText( wfMsg( "whitelistacctext" ) );
$wgOut->returnToMain( false );
}
/* private */ function mainLoginForm( $err )
{
global $wgUser, $wgOut, $wgLang;
global $wgDBname;
$le = wfMsg( "loginerror" );
$yn = wfMsg( "yourname" );
$yp = wfMsg( "yourpassword" );
$ypa = wfMsg( "yourpasswordagain" );
$rmp = wfMsg( "remembermypassword" );
$nuo = wfMsg( "newusersonly" );
$li = wfMsg( "login" );
$ca = wfMsg( "createaccount" );
$cam = wfMsg( "createaccountmail" );
$ye = wfMsg( "youremail" );
$efl = wfMsg( "emailforlost" );
$mmp = wfMsg( "mailmypassword" );
$endText = wfMsg( "loginend" );
if ( $endText = "&lt;loginend&gt;" ) {
$endText = "";
}
if ( "" == $this->mName ) {
if ( 0 != $wgUser->getID() ) {
$this->mName = $wgUser->getName();
} else {
$this->mName = @$_COOKIE["{$wgDBname}UserName"];
}
}
$wgOut->setPageTitle( wfMsg( "userlogin" ) );
$wgOut->setRobotpolicy( "noindex,nofollow" );
$wgOut->setArticleRelated( false );
if ( "" == $err ) {
$lp = wfMsg( "loginprompt" );
$wgOut->addHTML( "<h2>$li:</h2>\n<p>$lp</p>" );
} else {
$wgOut->addHTML( "<h2>$le:</h2>\n<font size='+1'
color='red'>$err</font>\n" );
}
if ( 1 == $wgUser->getOption( "rememberpassword" ) ) {
$checked = " checked";
} else {
$checked = "";
}
$q = "action=submit";
if ( !empty( $this->mReturnto ) ) {
$q .= "&returnto=" . wfUrlencode( $this->mReturnto );
}
$titleObj = Title::makeTitle( NS_SPECIAL, "Userlogin" );
$action = $titleObj->escapeLocalUrl( $q );
$encName = wfEscapeHTML( $this->mName );
$encPassword = wfEscapeHTML( $this->mPassword );
$encRetype = wfEscapeHTML( $this->mRetype );
$encEmail = wfEscapeHTML( $this->mEmail );
if ($wgUser->getID() != 0) {
$cambutton = "<input tabindex=6 type=submit name=\"wpCreateaccountMail\" value=\"{$cam}\">";
} else {
$cambutton = "";
}
$wgOut->addHTML( "
<form name=\"userlogin\" id=\"userlogin\" method=\"post\" action=\"{$action}\">
<table border=0><tr>
<td align=right>$yn:</td>
<td align=left>
<input tabindex=1 type=text name=\"wpName\" value=\"{$encName}\" size=20>
</td>
<td align=left>
<input tabindex=3 type=submit name=\"wpLoginattempt\" value=\"{$li}\">
</td>
</tr>
<tr>
<td align=right>$yp:</td>
<td align=left>
<input tabindex=2 type=password name=\"wpPassword\" value=\"{$encPassword}\" size=20>
</td>
<td align=left>
<input tabindex=7 type=checkbox name=\"wpRemember\" value=\"1\" id=\"wpRemember\"$checked><label for=\"wpRemember\">$rmp</label>
</td>
</tr>");
if ($wgUser->isAllowedToCreateAccount()) {
$encRetype = htmlspecialchars( $this->mRetype );
$encEmail = htmlspecialchars( $this->mEmail );
$wgOut->addHTML("<tr><td colspan=3>&nbsp;</td></tr><tr>
<td align=right>$ypa:</td>
<td align=left>
<input tabindex=4 type=password name=\"wpRetype\" value=\"{$encRetype}\"
size=20>
</td><td>$nuo</td></tr>
<tr>
<td align=right>$ye:</td>
<td align=left>
<input tabindex=5 type=text name=\"wpEmail\" value=\"{$encEmail}\" size=20>
</td><td align=left>
<input tabindex=6 type=submit name=\"wpCreateaccount\" value=\"{$ca}\">
$cambutton
</td></tr>");
}
$wgOut->addHTML("
<tr><td colspan=3>&nbsp;</td></tr><tr>
<td colspan=3 align=left>
<p>$efl<br>
<input tabindex=8 type=submit name=\"wpMailmypassword\" value=\"{$mmp}\">
</td></tr></table>
</form>\n" );
$wgOut->addHTML( $endText );
}
/* private */ function hasSessionCookie()
{
global $wgDisableCookieCheck;
return ( $wgDisableCookieCheck ) ? true : ( "" != $_COOKIE[session_name()] );
}
return $u;
}
/* private */ function cookieRedirectCheck( $type )
{
global $wgOut, $wgLang;
$titleObj = Title::makeTitle( NS_SPECIAL, "Userlogin" );
$check = $titleObj->getFullURL( "wpCookieCheck=$type" );
/* private */ function successfulLogin( $msg )
{
global $wgUser;
global $wgDeferredUpdateList;
global $wgOut;
$wgOut->setPageTitle( wfMsg( "loginsuccesstitle" ) );
$wgOut->setRobotpolicy( "noindex,nofollow" );
$wgOut->setArticleRelated( false );
$wgOut->addHTML( $msg . "\n<p>" );
$wgOut->returnToMain();
}
function userNotPrivilegedMessage()
{
global $wgOut, $wgUser, $wgLang;
$wgOut->setPageTitle( wfMsg( "whitelistacctitle" ) );
$wgOut->setRobotpolicy( "noindex,nofollow" );
$wgOut->setArticleRelated( false );
$wgOut->addWikiText( wfMsg( "whitelistacctext" ) );
$wgOut->returnToMain( false );
}
/* private */ function mainLoginForm( $err )
{
global $wgUser, $wgOut, $wgLang;
global $wgRequest, $wgDBname;
$le = wfMsg( "loginerror" );
$yn = wfMsg( "yourname" );
$yp = wfMsg( "yourpassword" );
$ypa = wfMsg( "yourpasswordagain" );
$rmp = wfMsg( "remembermypassword" );
$nuo = wfMsg( "newusersonly" );
$li = wfMsg( "login" );
$ca = wfMsg( "createaccount" );
$cam = wfMsg( "createaccountmail" );
$ye = wfMsg( "youremail" );
$efl = wfMsg( "emailforlost" );
$mmp = wfMsg( "mailmypassword" );
$endText = wfMsg( "loginend" );
if ( $endText = "&lt;loginend&gt;" ) {
$endText = "";
return $wgOut->redirect( $check );
}
$name = $wgRequest->getText( 'wpName' );
if ( "" == $name ) {
if ( 0 != $wgUser->getID() ) {
$name = $wgUser->getName();
/* private */ function onCookieRedirectCheck( $type ) {
global $wgUser;
if ( !$this->hasSessionCookie() ) {
if ( $type == "new" ) {
return $this->mainLoginForm( wfMsg( "nocookiesnew" ) );
} else if ( $type == "login" ) {
return $this->mainLoginForm( wfMsg( "nocookieslogin" ) );
} else {
# shouldn't happen
return $this->mainLoginForm( wfMsg( "error" ) );
}
} else {
$name = @$_COOKIE["{$wgDBname}UserName"];
return $this->successfulLogin( wfMsg( "loginsuccess", $wgUser->getName() ) );
}
}
$pwd = $wgRequest->getText( 'wpPassword' );
$wgOut->setPageTitle( wfMsg( "userlogin" ) );
$wgOut->setRobotpolicy( "noindex,nofollow" );
$wgOut->setArticleRelated( false );
if ( "" == $err ) {
$lp = wfMsg( "loginprompt" );
$wgOut->addHTML( "<h2>$li:</h2>\n<p>$lp</p>" );
} else {
$wgOut->addHTML( "<h2>$le:</h2>\n<font size='+1'
color='red'>$err</font>\n" );
}
if ( 1 == $wgUser->getOption( "rememberpassword" ) ) {
$checked = " checked";
} else {
$checked = "";
}
$q = "action=submit";
$returnto = $wgRequest->getVal( "returnto" );
if ( !empty( $returnto ) ) {
$q .= "&returnto=" . wfUrlencode( $returnto );
}
$titleObj = Title::makeTitle( NS_SPECIAL, "Userlogin" );
$action = $titleObj->escapeLocalUrl( $q );
$encName = wfEscapeHTML( $name );
$encPassword = wfEscapeHTML( $pwd );
$encRetype = wfEscapeHTML( $wgRequest->getText( 'wpRetype' ) );
$encEmail = wfEscapeHTML( $wgRequest->getVal( 'wpEmail' ) );
if ($wgUser->getID() != 0) {
$cambutton = "<input tabindex=6 type=submit name=\"wpCreateaccountMail\" value=\"{$cam}\">";
} else {
$cambutton = "";
}
$wgOut->addHTML( "
<form name=\"userlogin\" id=\"userlogin\" method=\"post\" action=\"{$action}\">
<table border=0><tr>
<td align=right>$yn:</td>
<td align=left>
<input tabindex=1 type=text name=\"wpName\" value=\"{$encName}\" size=20>
</td>
<td align=left>
<input tabindex=3 type=submit name=\"wpLoginattempt\" value=\"{$li}\">
</td>
</tr>
<tr>
<td align=right>$yp:</td>
<td align=left>
<input tabindex=2 type=password name=\"wpPassword\" value=\"{$encPassword}\" size=20>
</td>
<td align=left>
<input tabindex=7 type=checkbox name=\"wpRemember\" value=\"1\" id=\"wpRemember\"$checked><label for=\"wpRemember\">$rmp</label>
</td>
</tr>");
if ($wgUser->isAllowedToCreateAccount()) {
$encRetype = htmlspecialchars( $wgRequest->getText( 'wpRetype' ) );
$encEmail = htmlspecialchars( $wgRequest->getText( 'wpEmail' ) );
$wgOut->addHTML("<tr><td colspan=3>&nbsp;</td></tr><tr>
<td align=right>$ypa:</td>
<td align=left>
<input tabindex=4 type=password name=\"wpRetype\" value=\"{$encRetype}\"
size=20>
</td><td>$nuo</td></tr>
<tr>
<td align=right>$ye:</td>
<td align=left>
<input tabindex=5 type=text name=\"wpEmail\" value=\"{$encEmail}\" size=20>
</td><td align=left>
<input tabindex=6 type=submit name=\"wpCreateaccount\" value=\"{$ca}\">
$cambutton
</td></tr>");
}
$wgOut->addHTML("
<tr><td colspan=3>&nbsp;</td></tr><tr>
<td colspan=3 align=left>
<p>$efl<br>
<input tabindex=8 type=submit name=\"wpMailmypassword\" value=\"{$mmp}\">
</td></tr></table>
</form>\n" );
$wgOut->addHTML( $endText );
}
/* private */ function hasSessionCookie()
{
global $wgDisableCookieCheck;
return ( $wgDisableCookieCheck ) ? true : ( "" != $_COOKIE[session_name()] );
}
/* private */ function cookieRedirectCheck( $type )
{
global $wgOut, $wgLang;
$titleObj = Title::makeTitle( NS_SPECIAL, "Userlogin" );
$check = $titleObj->getFullURL( "wpCookieCheck=$type" );
return $wgOut->redirect( $check );
}
/* private */ function onCookieRedirectCheck( $type ) {
global $wgUser;
if ( !hasSessionCookie() ) {
if ( $type == "new" ) {
return mainLoginForm( wfMsg( "nocookiesnew" ) );
} else if ( $type == "login" ) {
return mainLoginForm( wfMsg( "nocookieslogin" ) );
} else {
# shouldn't happen
return mainLoginForm( wfMsg( "error" ) );
}
} else {
return successfulLogin( wfMsg( "loginsuccess", $wgUser->getName() ) );
}
}
?>