The plan here is to take it out of 1.27.0-wmf.12 and put it back in 1.27.0-wmf.13. Since BotPasswords depends on SessionManager, that's getting temporarily removed too. This reverts the following commits: *6acd424e0dSessionManager: Notify AuthPlugin before calling hooks *4d1ad32d8aClose a loophole in CookieSessionProvider *fcdd643a46SessionManager: Don't save non-persisted sessions to backend storage *058aec4c76MessageCache: Don't get a ParserOptions for $wgUser before the end of Setup.php *b5c0c03bb7SessionManager: Save user name to metadata even if the user doesn't exist locally *13f2f09a19SECURITY: Fix User::setToken() call on User::newSystemUser *305bc75b27SessionManager: Don't generate user tokens when checking the tokens *7c4bd85d21RequestContext::exportSession() should only export persisted session IDs *296ccfd4a9SessionManager: Save 'persisted' flag in session metadata *94ba53f677Move CSRF token handling into MediaWiki\Session\Session *46a565d6b0Avoid false "added in both Session and $_SESSION" when value is null *c00d0b5d94Log backtrace for "User::loadFromSession called before the end of Setup.php" *4eeff5b559Use $wgSecureCookie to decide whether to actually mark secure cookies as 'secure' *7491b52f70Call session_cache_limiter() before starting a session *2c34aeea72SessionManager: Abstract forceHTTPS cookie setting *9aa53627a5Ignore auth cookies with value 'deleted' *43f904b51aSessionManager: Kill getPersistedSessionId() *50c5256352SessionManager: Add SessionBackend::setProviderMetadata() *f640d40315SessionManager: Notify AuthPlugin when auto-creating accounts *70b05d1ac1Add checks of $wgEnableBotPasswords in more places *bfed32eb78Do not raise a PHP warning when session write fails *722a7331adOnly check LoggedOut timestamp on the user loaded from session *4f5057b84bSessionManager: Change behavior of getSessionById() *66e82e614eFix typo in [[MediaWiki:Botpasswords-editexisting/en]] *f9fd9516d9Add "bot passwords" *d7716f1df0Add missing argument for wfDebugLog *a73c5b7395Add SessionManager Change-Id: I2389a8133e25ab929e9f27f41fa9a05df8147a50
87 lines
2.4 KiB
PHP
87 lines
2.4 KiB
PHP
<?php
|
|
/**
|
|
* Deal with importing all those nasty globals and things
|
|
*
|
|
* Copyright © 2003 Brion Vibber <brion@pobox.com>
|
|
* https://www.mediawiki.org/
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License along
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
* http://www.gnu.org/copyleft/gpl.html
|
|
*
|
|
* @file
|
|
*/
|
|
|
|
/**
|
|
* Similar to FauxRequest, but only fakes URL parameters and method
|
|
* (POST or GET) and use the base request for the remaining stuff
|
|
* (cookies, session and headers).
|
|
*
|
|
* @ingroup HTTP
|
|
* @since 1.19
|
|
*/
|
|
class DerivativeRequest extends FauxRequest {
|
|
private $base;
|
|
|
|
/**
|
|
* @param WebRequest $base
|
|
* @param array $data Array of *non*-urlencoded key => value pairs, the
|
|
* fake GET/POST values
|
|
* @param bool $wasPosted Whether to treat the data as POST
|
|
*/
|
|
public function __construct( WebRequest $base, $data, $wasPosted = false ) {
|
|
$this->base = $base;
|
|
parent::__construct( $data, $wasPosted );
|
|
}
|
|
|
|
public function getCookie( $key, $prefix = null, $default = null ) {
|
|
return $this->base->getCookie( $key, $prefix, $default );
|
|
}
|
|
|
|
public function checkSessionCookie() {
|
|
return $this->base->checkSessionCookie();
|
|
}
|
|
|
|
public function getHeader( $name, $flags = 0 ) {
|
|
return $this->base->getHeader( $name, $flags );
|
|
}
|
|
|
|
public function getAllHeaders() {
|
|
return $this->base->getAllHeaders();
|
|
}
|
|
|
|
public function getSessionData( $key ) {
|
|
return $this->base->getSessionData( $key );
|
|
}
|
|
|
|
public function setSessionData( $key, $data ) {
|
|
$this->base->setSessionData( $key, $data );
|
|
}
|
|
|
|
public function getAcceptLang() {
|
|
return $this->base->getAcceptLang();
|
|
}
|
|
|
|
public function getIP() {
|
|
return $this->base->getIP();
|
|
}
|
|
|
|
public function getProtocol() {
|
|
return $this->base->getProtocol();
|
|
}
|
|
|
|
public function getElapsedTime() {
|
|
return $this->base->getElapsedTime();
|
|
}
|
|
}
|