Merge "Allow API action=logout with BotPasswords"
authorjenkins-bot <jenkins-bot@gerrit.wikimedia.org>
Tue, 1 Mar 2016 11:12:20 +0000 (11:12 +0000)
committerGerrit Code Review <gerrit@wikimedia.org>
Tue, 1 Mar 2016 11:12:20 +0000 (11:12 +0000)
includes/api/ApiLogout.php

index 2c38208..6a26e2e 100644 (file)
@@ -24,6 +24,8 @@
  * @file
  */
 
+use MediaWiki\Session\BotPasswordSessionProvider;
+
 /**
  * API module to allow users to log out of the wiki. API equivalent of
  * Special:Userlogout.
 class ApiLogout extends ApiBase {
 
        public function execute() {
-               // Make sure it's possible to log out
                $session = MediaWiki\Session\SessionManager::getGlobalSession();
+
+               // Handle bot password logout specially
+               if ( $session->getProvider() instanceof BotPasswordSessionProvider ) {
+                       $session->unpersist();
+                       return;
+               }
+
+               // Make sure it's possible to log out
                if ( !$session->canSetUser() ) {
                        $this->dieUsage(
                                'Cannot log out when using ' .