Ok, per usare l'archivio di amministrazione negli script di aggiornamento basta usare
Mage::app()->setCurrentStore(Mage_Core_Model_App::ADMIN_STORE_ID);
Il tuo approccio Mage::app()->setCurrentStore(Mage::getModel('core/store')->load(Mage_Core_Model_App::ADMIN_STORE_ID));
non può avere successo, perché non esiste alcuna storeview caricabile realmente esistente per admin
Spesso uso un modello come questo:
// 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());
Altrimenti a volte dopo l'esecuzione di uno script di aggiornamento i visitatori verranno reindirizzati alla pagina di amministrazione anziché a volte al frontend.
Aggiornare:
Ho frainteso la seguente domanda, quindi ecco un nuovo tentativo di spiegare ^^
Gli script di aggiornamento sono chiamati da un metodo più profondo nel core ( Mage_Core_Model_Resource_Setup::_modifyResourceDb(...)
)
Qui ho provato ad elencare lo stack
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 ora dai un'occhiata 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;
}
il metodo _initModules()
viene chiamato prima di $scopeCode
e $scopeType
viene determinato.
Attualmente non riesco a capire dove sia definito il fallback ipotizzato.