| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158 | <?php/** * MageSpecialist * * NOTICE OF LICENSE * * This source file is subject to the Open Software License (OSL 3.0) * that is bundled with this package in the file LICENSE.txt. * It is also available through the world-wide-web at this URL: * http://opensource.org/licenses/osl-3.0.php * If you did not receive a copy of the license and are unable to * obtain it through the world-wide-web, please send an email * to info@magespecialist.it so we can send you a copy immediately. * * @copyright  Copyright (c) 2017 Skeeller srl (http://www.magespecialist.it) * @license    http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0) */namespace MSP\TwoFactorAuth\Controller\Adminhtml\U2f;use Magento\Backend\App\Action;use Magento\Backend\Model\Auth\Session;use Magento\Framework\App\ResponseInterface;use Magento\Framework\Controller\Result\JsonFactory;use Magento\Framework\DataObjectFactory;use MSP\TwoFactorAuth\Model\AlertInterface;use MSP\TwoFactorAuth\Api\TfaSessionInterface;use MSP\TwoFactorAuth\Api\TrustedManagerInterface;use MSP\TwoFactorAuth\Controller\Adminhtml\AbstractAction;use MSP\TwoFactorAuth\Model\Provider\Engine\U2fKey;use MSP\TwoFactorAuth\Model\Tfa;/** * @SuppressWarnings(PHPMD.CouplingBetweenObjects) * @SuppressWarnings(PHPMD.CamelCaseMethodName) */class Authpost extends AbstractAction{    /**     * @var Tfa     */    private $tfa;    /**     * @var Session     */    private $session;    /**     * @var U2fKey     */    private $u2fKey;    /**     * @var JsonFactory     */    private $jsonFactory;    /**     * @var TfaSessionInterface     */    private $tfaSession;    /**     * @var TrustedManagerInterface     */    private $trustedManager;    /**     * @var DataObjectFactory     */    private $dataObjectFactory;    /**     * @var AlertInterface     */    private $alert;    public function __construct(        Tfa $tfa,        Session $session,        JsonFactory $jsonFactory,        TfaSessionInterface $tfaSession,        TrustedManagerInterface $trustedManager,        U2fKey $u2fKey,        DataObjectFactory $dataObjectFactory,        AlertInterface $alert,        Action\Context $context    ) {        parent::__construct($context);        $this->tfa = $tfa;        $this->session = $session;        $this->u2fKey = $u2fKey;        $this->jsonFactory = $jsonFactory;        $this->tfaSession = $tfaSession;        $this->trustedManager = $trustedManager;        $this->dataObjectFactory = $dataObjectFactory;        $this->alert = $alert;    }    /**     * Dispatch request     *     * @return \Magento\Framework\Controller\ResultInterface|ResponseInterface     */    public function execute()    {        $result = $this->jsonFactory->create();        try {            $this->u2fKey->verify($this->getUser(), $this->dataObjectFactory->create([                'data' => $this->getRequest()->getParams(),            ]));            $this->tfaSession->grantAccess();            $this->trustedManager->handleTrustDeviceRequest(U2fKey::CODE, $this->getRequest());            $res = ['success' => true];        } catch (\Exception $e) {            $this->alert->event(                'MSP_TwoFactorAuth',                'U2F error',                AlertInterface::LEVEL_ERROR,                $this->getUser()->getUserName(),                AlertInterface::ACTION_LOG,                $e->getMessage()            );            $res = ['success' => false, 'message' => $e->getMessage()];        }        $result->setData($res);        return $result;    }    /**     * @return \Magento\User\Model\User|null     */    private function getUser()    {        return $this->session->getUser();    }    /**     * Check if admin has permissions to visit related pages     *     * @return bool     */    protected function _isAllowed()    {        $user = $this->getUser();        return            $user &&            $this->tfa->getProviderIsAllowed($user->getId(), U2fKey::CODE) &&            $this->tfa->getProvider(U2fKey::CODE)->isActive($user->getId());    }}
 |