Ok, para usar la tienda de administración en tus scripts de actualización solo usa
Mage::app()->setCurrentStore(Mage_Core_Model_App::ADMIN_STORE_ID);
Su enfoque Mage::app()->setCurrentStore(Mage::getModel('core/store')->load(Mage_Core_Model_App::ADMIN_STORE_ID));
no puede tener éxito, porque no hay realmente una vista de tienda cargable para el administrador
A menudo uso un patrón como este:
// remembering old current store
$currentStore = Mage::app()->getCurrentStore();
// switching to admin store
Mage::app()->setCurrentStore(Mage_Core_Model_App::ADMIN_STORE_ID);
// switching back to old current store
Mage::app()->setCurrentStore($currentStore->getStoreId());
De lo contrario, a veces, después de ejecutar un script de actualización, sus visitantes serán redirigidos a la página de administración en lugar de a la interfaz.
Actualizar:
Interpreté mal la pregunta a continuación, así que aquí hay un nuevo intento de explicar ^^
Los scripts de actualización se invocan desde un método más profundo en el núcleo ( Mage_Core_Model_Resource_Setup::_modifyResourceDb(...)
)
Aquí intenté enumerar la pila
Mage_Core_Model_App::run($params)
Mage_Core_Model_App::_initModules()
Mage_Core_Model_Resource_Setup::applyAllUpdates()
Mage_Core_Model_Resource_Setup::applyUpdates()
Mage_Core_Model_Resource_Setup::_upgradeResourceDb($oldVersion, $newVersion)
Mage_Core_Model_Resource_Setup::_modifyResourceDb($actionType, $fromVersion, $toVersion)
y ahora echa un vistazo a Mage_Core_model_App::run($params)
:
public function run($params)
{
$options = isset($params['options']) ? $params['options'] : array();
$this->baseInit($options);
Mage::register('application_params', $params);
if ($this->_cache->processRequest()) {
$this->getResponse()->sendResponse();
} else {
$this->_initModules();
$this->loadAreaPart(Mage_Core_Model_App_Area::AREA_GLOBAL, Mage_Core_Model_App_Area::PART_EVENTS);
if ($this->_config->isLocalConfigLoaded()) {
$scopeCode = isset($params['scope_code']) ? $params['scope_code'] : '';
$scopeType = isset($params['scope_type']) ? $params['scope_type'] : 'store';
$this->_initCurrentStore($scopeCode, $scopeType);
$this->_initRequest();
Mage_Core_Model_Resource_Setup::applyAllDataUpdates();
}
$this->getFrontController()->dispatch();
}
return $this;
}
el método _initModules()
se llama antes $scopeCode
y $scopeType
se determina el.
Actualmente no puedo entender dónde se define el retroceso supuesto.