Ok, para usar o repositório de administradores em seus scripts de atualização, basta usar
Mage::app()->setCurrentStore(Mage_Core_Model_App::ADMIN_STORE_ID);
Sua abordagem Mage::app()->setCurrentStore(Mage::getModel('core/store')->load(Mage_Core_Model_App::ADMIN_STORE_ID));
não pode ser bem-sucedida, pois não há uma visualização de armazenamento carregável realmente existente para o administrador
Muitas vezes eu uso um padrão 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());
Caso contrário, algumas vezes, após a execução de um script de atualização, os visitantes serão redirecionados para a página de administração, e não para o frontend às vezes.
Atualizar:
Eu interpretei mal a pergunta abaixo, então aqui está uma nova tentativa de explicar ^^
Os scripts de atualização são chamados de um método mais profundo no núcleo (Mage_Core_Model_Resource_Setup::_modifyResourceDb(...)
)
Aqui eu tentei listar a pilha
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)
e agora dê uma olhada em 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;
}
o método _initModules()
é chamado antes de $scopeCode
e $scopeType
é determinado.
Atualmente, não consigo descobrir onde o fallback assumido está definido.