Alterando e consultando as configurações da loja pela Visão – Magento 2

Magento 2 salva e centraliza todas as configurações de adminhtml na tabela core_config no seu banco de dados.

Lá você pode obter valores por seu “caminho”, uma string que indica caminho e um nome de variável. Com esse caminho, você pode obter ou definir valores pelos métodos principais do Magento 2. Para isso, você precisa usar: \ Magento \ Framework \ App \ Config \ Armazenamento \ WriteInterface gravar valores de configuração no banco de dados \ Magento \ Framework \ App \ Config \ ScopeConfigInterface ler valores de configuração do banco de dados

Aqui está como isso funciona com código de amostra.

Alterar Configuração

O código a seguir mostra como gravar valores de configuração delimitando por escopo/visão da loja:

class WriteConfig
{
    protected $_logger;
    protected $_storeManager;
    protected $_configWriter;
 
    public function __construct(
        \Psr\Log\LoggerInterface $logger,
        \Magento\Framework\App\Config\Storage\WriterInterface $configWriter,
        \Magento\Store\Model\StoreManagerInterface $storeManager
    ){
        $this->_logger = $logger;
        $this->_configWriter = $configWriter;
        $this->_storeManager = $storeManager;
    }
 
    public function setConfig($value)
    {
        //for all websites
        $websites = $this->_storeManager->getWebsites();
        $scope = "websites";
        foreach($websites as $website) {
            echo $website->getId().":\n";
 
            $this->_configWriter->save('my_section/something/configvaluename', $value, $scope, $website->getId());
        }
 
        return $this;
    }
}

Consultando uma configuração

Agora é hora de ler os dados. Você pode fazer isso com o código a seguir:

class ReadConfig
{
    protected $_scopeConfig;
 
    public function __construct(
        \Magento\Framework\App\Helper\Context $context,
        \Magento\Framework\App\Config\ScopeConfigInterface $scopeConfig
    ){
        $this->_scopeConfig = $scopeConfig;
        parent::__construct($context);
    }
 
    public function getConfig() {
        return $this->_scopeConfig->getValue("my_section/something/configvaluename", "websites");
    }
}

É muito fácil, você só precisa usar o método getValue () e adicionar um segundo parâmetro com o escopo (aqui usamos o escopo do site). Isso retornará o valor armazenado para o site atual.

Avalie este artigo!

Clique nas estrelas, para dar uma nota de 1 à 5.

Dúvidas? Faça um comentário logo abaixo ou envie uma mensagem clicando aqui.

O seu endereço de e-mail não será publicado. Campos obrigatórios são marcados com *