<?php
/**
- * @file src/Module/Logout.php
+ * @copyright Copyright (C) 2010-2021, the Friendica project
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 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 Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <https://www.gnu.org/licenses/>.
+ *
*/
namespace Friendica\Module\Security;
use Friendica\Core\System;
use Friendica\DI;
use Friendica\Model\Profile;
+use Friendica\Security\TwoFactor;
/**
* Logout module
- *
- * @author Hypolite Petovan <hypolite@mrpetovan.com>
*/
class Logout extends BaseModule
{
/**
- * @brief Process logout requests
+ * Process logout requests
*/
public static function init(array $parameters = [])
{
}
Hook::callAll("logging_out");
+
+ // Remove this trusted browser as it won't be able to be used ever again after the cookie is cleared
+ if (DI::cookie()->get('trusted')) {
+ $trustedBrowserRepository = new TwoFactor\Repository\TrustedBrowser(DI::dba(), DI::logger());
+ $trustedBrowserRepository->removeForUser(local_user(), DI::cookie()->get('trusted'));
+ }
+
DI::cookie()->clear();
DI::session()->clear();