| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161 | <?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. * * @category   MSP * @package    MSP_TwoFactorAuth * @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\Authy;use Magento\Backend\App\Action;use Magento\Backend\Model\Auth\Session;use Magento\Framework\Controller\Result\JsonFactory;use Magento\Framework\View\Result\PageFactory;use MSP\TwoFactorAuth\Model\AlertInterface;use MSP\TwoFactorAuth\Api\TfaInterface;use MSP\TwoFactorAuth\Api\UserConfigManagerInterface;use MSP\TwoFactorAuth\Controller\Adminhtml\AbstractAction;use MSP\TwoFactorAuth\Model\Provider\Engine\Authy;/** * @SuppressWarnings(PHPMD.CamelCaseMethodName) */class Configurepost extends AbstractAction{    /**     * @var PageFactory     */    private $jsonFactory;    /**     * @var Session     */    private $session;    /**     * @var TfaInterface     */    private $tfa;    /**     * @var AlertInterface     */    private $alert;    /**     * @var Authy\Verification     */    private $verification;    /**     * @var UserConfigManagerInterface     */    private $userConfigManager;    /**     * Configurepost constructor.     * @param Action\Context $context     * @param Session $session     * @param Authy\Verification $verification     * @param UserConfigManagerInterface $userConfigManager     * @param TfaInterface $tfa     * @param AlertInterface $alert     * @param JsonFactory $jsonFactory     */    public function __construct(        Action\Context $context,        Session $session,        Authy\Verification $verification,        UserConfigManagerInterface $userConfigManager,        TfaInterface $tfa,        AlertInterface $alert,        JsonFactory $jsonFactory    ) {        parent::__construct($context);        $this->jsonFactory = $jsonFactory;        $this->session = $session;        $this->tfa = $tfa;        $this->alert = $alert;        $this->verification = $verification;        $this->userConfigManager = $userConfigManager;    }    /**     * Get current user     * @return \Magento\User\Model\User|null     */    private function getUser()    {        return $this->session->getUser();    }    /**     * @inheritdoc     */    public function execute()    {        $request = $this->getRequest();        $response = $this->jsonFactory->create();        try {            $this->verification->request(                $this->getUser(),                $request->getParam('tfa_country'),                $request->getParam('tfa_phone'),                $request->getParam('tfa_method'),                $res            );            $this->alert->event(                'MSP_TwoFactorAuth',                'New authy verification request via ' . $request->getParam('tfa_method'),                AlertInterface::LEVEL_INFO,                $this->getUser()->getUserName()            );            $response->setData([                'success' => true,                'message' => $res['message'],                'seconds_to_expire' => (int) $res['seconds_to_expire'],            ]);        } catch (\Exception $e) {            $this->alert->event(                'MSP_TwoFactorAuth',                'Authy verification request failure via ' . $request->getParam('tfa_method'),                AlertInterface::LEVEL_ERROR,                $this->getUser()->getUserName(),                AlertInterface::ACTION_LOG,                $e->getMessage()            );            $response->setData(['success' => false, 'message' => $e->getMessage()]);        }        return $response;    }    /**     * @inheritdoc     */    protected function _isAllowed()    {        $user = $this->getUser();        return            $user &&            $this->tfa->getProviderIsAllowed($user->getId(), Authy::CODE) &&            !$this->tfa->getProvider(Authy::CODE)->isActive($user->getId());    }}
 |