![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/old/vendor/magento/module-two-factor-auth/Model/Config/Backend/ |
<?php /** * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */ declare(strict_types=1); namespace Magento\TwoFactorAuth\Model\Config\Backend; use Magento\Framework\App\Cache\TypeListInterface; use Magento\Framework\App\Config\ScopeConfigInterface; use Magento\Framework\App\Config\Value; use Magento\Framework\Data\Collection\AbstractDb; use Magento\Framework\Exception\ValidatorException; use Magento\Framework\Model\Context; use Magento\Framework\Model\ResourceModel\AbstractResource; use Magento\Framework\Registry; use Magento\TwoFactorAuth\Api\TfaInterface; /** * Managing "Force Providers" config value. */ class ForceProviders extends Value { /** * @var TfaInterface */ private $tfa; /** * @param Context $context * @param Registry $registry * @param ScopeConfigInterface $config * @param TypeListInterface $cacheTypeList * @param TfaInterface $tfa * @param AbstractResource|null $resource * @param AbstractDb|null $resourceCollection * @param array $data */ public function __construct( Context $context, Registry $registry, ScopeConfigInterface $config, TypeListInterface $cacheTypeList, TfaInterface $tfa, AbstractResource $resource = null, AbstractDb $resourceCollection = null, array $data = [] ) { parent::__construct( $context, $registry, $config, $cacheTypeList, $resource, $resourceCollection, $data ); $this->tfa = $tfa; } /** * @inheritDoc */ public function beforeSave() { $codes = []; $providers = $this->tfa->getAllProviders(); foreach ($providers as $provider) { $codes[] = $provider->getCode(); } $value = $this->getValue(); if (is_string($value)) { $value = explode(',', $value); } $validValues = is_array($value) ? array_intersect($codes, $value) : []; if (empty($value) || !$validValues) { throw new ValidatorException(__('You have to select at least one Two-Factor Authorization provider')); } // Removes invalid codes $this->setValue($validValues); return parent::beforeSave(); } }