Erro após o êxito do patch SUPEE-5994: Classe 'Mage_Install_Controller_Router_Install' não encontrada

36

Instalei com êxito o patch SUPEE-5994:

[root@x]# sh PATCH_SUPEE-5994_EE_1.14.1.0_v1-2015-05-14-05-05-02.sh
Checking if patch can be applied/reverted successfully...
Patch was applied/reverted successfully.

Mas agora, todas as minhas páginas da web estão em branco.

O log de erros httpd:

[error] [client x] PHP Erro fatal: Classe 'Mage_Install_Controller_Router_Install' não encontrada em /var/www/x/public_html/app/code/core/Mage/Core/Controller/Varien/Front.php na linha 138

Eu tentei:

  • Limpe o / var / cache
  • Redefinir o chmod / chown
  • Reinicie o serviço httpd

Mas nada parece funcionar.

Alguém tem o mesmo problema ?

EDIT: O arquivo Front.php:

 Varien_Profiler::start('mage::app::init_front_controller::collect_routers');
    foreach ($routersInfo as $routerCode => $routerInfo) {
        if (isset($routerInfo['disabled']) && $routerInfo['disabled']) {
            continue;
        }
        if (isset($routerInfo['class'])) {
   // LINE 138 HERE
            $router = new $routerInfo['class'];
            if (isset($routerInfo['area'])) {
                $router->collectRoutes($routerInfo['area'], $routerCode);
            }
            $this->addRouter($routerCode, $router);
        }
    }
    Varien_Profiler::stop('mage::app::init_front_controller::collect_routers');
Cqke
fonte

Respostas:

38

Você desligou e limpou a compilação?

através do console / ssh você pode usar

$ php -f shell/compiler.php -- disable

$ php -f shell/compiler.php -- clear

$ php -f shell/compiler.php -- compile

$ php -f shell/compiler.php -- enable

pode precisar da quarta linha ... não tenho certeza.

Pode haver um problema com a linha anterior ao código que você mostrou

$routersInfo = Mage::app()->getStore()->getConfig(self::XML_STORE_ROUTERS_PATH);

Nota: Eu tive um problema semelhante em que o administrador estava em branco, mas acabou sendo um arquivo em um módulo que estava substituindo um dos arquivos principais - mas esse não é o seu caso. Apenas no caso de outros olharem para isso com esse problema.

Jon Holland
fonte
Uau, você é o cara! Muito Obrigado. Apenas edite a terceira linha, era php -f shell / compiler.php - compile para mim. Funciona !
Cqke 15/05
1
Legal. Tinham sites de atualização problema real na semana passada companheiro :) Fico feliz em ajudar
Jon Holland
1
Atualizado bom local.
Jon Holland
É para isso que servem os votos, Jon
David Wilkins
:) você realmente sabe, David. Apenas bom ver as pessoas saindo de uma pickle.
Jon Holland
14

Se você desabilitou o compilador e limpou o cache e ainda se depara com o erro

Class 'Mage_Install_Controller_Router_Install' not found

Verifique se o arquivo app/code/core/Mage/Install/Controller/Router/Install.php existe.

Quando você executou o patch, o diretório Routernão existia app/code/core/Mage/Install/Controllere, portanto, o Install.phparquivo não foi criado, apesar de ser informado de outra forma no applied.patches.listarquivo. Isso significa que você está perdendo uma aula e recebe a mensagem:

Fatal error: Class 'Mage_Install_Controller_Router_Install' not found

Trecho da applied.patches.listinstalação do patch supostamente bem-sucedida que falha ao criar o arquivo Install.php:

patching file app/code/core/Mage/Install/Controller/Router/Install.php
patching file app/code/core/Mage/Install/etc/config.xml

O patch cria a seguinte adição ao app/code/core/Mage/Install/etc/config.xmlarquivo que referencia o arquivo ausente:

 <default>
     <web>
         <routers>
             <install>
                 <area>frontend</area>
                 <class>Mage_Install_Controller_Router_Install</class>
             </install>
         </routers>
     </web>
 </default>
 <stores>
     <default>
         <web>
             <routers>
                 <install>
                     <area>frontend</area>
                     <class>Mage_Install_Controller_Router_Install</class>
                 </install>
             </routers>
         </web>
     </default>
 </stores>

Amostra do que o arquivo ausente app/code/core/Mage/Install/Controller/Router/Install.phpdeve conter.

<?php
/**
 * Magento Enterprise Edition
 *
 * NOTICE OF LICENSE
 *
 * This source file is subject to the Magento Enterprise Edition End User License Agreement
 * that is bundled with this package in the file LICENSE_EE.txt.
 * It is also available through the world-wide-web at this URL:
 * http://www.magento.com/license/enterprise-edition
 * 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 [email protected] so we can send you a copy immediately.
 *
 * DISCLAIMER
 *
 * Do not edit or add to this file if you wish to upgrade Magento to newer
 * versions in the future. If you wish to customize Magento for your
 * needs please refer to http://www.magento.com for more information.
 *
 * @category    Mage
 * @package     Mage_Install
 * @copyright Copyright (c) 2006-2014 X.commerce, Inc. (http://www.magento.com)
 * @license http://www.magento.com/license/enterprise-edition
 */

class Mage_Install_Controller_Router_Install extends Mage_Core_Controller_Varien_Router_Standard
{
    /**
     * Check if current controller instance is allowed in current router.
     * 
     * @param Mage_Core_Controller_Varien_Action $controllerInstance
     * @return boolean
     */
    protected function _validateControllerInstance($controllerInstance)
    {
        return $controllerInstance instanceof Mage_Install_Controller_Action;
    }
}
Fiasco Labs
fonte
1
Além disso, Fiasco Labs, ouvi pessoas com esse problema.
Jon Holland
1
Descreve exatamente o que aconteceu no nosso caso e o problema acima foi resolvido. Obrigado
Flipmedia