* @link https://www.oxidmodule.com */ declare(strict_types=1); namespace D3\Totp\Modules\Core; use D3\TestingTools\Production\IsMockable; use D3\Totp\Application\Model\d3totp; use D3\Totp\Application\Model\d3totp_conf; use D3\Totp\Modules\Application\Model\d3_totp_user; use OxidEsales\Eshop\Application\Model\User; use OxidEsales\Eshop\Core\Registry; use OxidEsales\Eshop\Core\Session; use OxidEsales\Eshop\Core\Utils; class totpSystemEventHandler extends totpSystemEventHandler_parent { use IsMockable; public function onAdminLogin() { $this->d3RequestTotp(); $this->d3CallMockableParent('onAdminLogin'); } protected function d3requestTotp() { $totp = $this->d3GetTotpObject(); $userId = $this->d3TotpGetSession()->getVariable(d3totp_conf::OXID_ADMIN_AUTH); $totp->loadByUserId($userId); if ($this->d3TotpLoginMissing($totp)) { /** @var d3_totp_user $user */ $user = $this->d3TotpGetUserObject(); $user->logout(); $this->d3TotpGetSession()->setVariable(d3totp_conf::SESSION_ADMIN_CURRENTUSER, $userId); $this->getUtilsObject()->redirect( 'index.php?cl=d3totpadminlogin&'. 'profile='.$this->d3TotpGetSession()->getVariable(d3totp_conf::SESSION_ADMIN_PROFILE).'&'. 'chlanguage='.$this->d3TotpGetSession()->getVariable(d3totp_conf::SESSION_ADMIN_CHLANGUAGE), false ); } } /** * @return d3totp */ public function d3GetTotpObject() { return oxNew(d3totp::class); } /** * @return Utils */ public function getUtilsObject(): Utils { return Registry::getUtils(); } /** * @return Session */ public function d3TotpGetSession() { return Registry::getSession(); } /** * @param d3totp $totp * @return bool */ public function d3TotpLoginMissing($totp) { return $totp->isActive() && false == $this->d3TotpGetSession()->getVariable(d3totp_conf::SESSION_ADMIN_AUTH); } /** * @return User */ protected function d3TotpGetUserObject(): User { return oxNew(User::class); } }