Хорошо, чтобы использовать хранилище администратора в ваших скриптах обновления, просто используйте
Mage::app()->setCurrentStore(Mage_Core_Model_App::ADMIN_STORE_ID);
Ваш подход Mage::app()->setCurrentStore(Mage::getModel('core/store')->load(Mage_Core_Model_App::ADMIN_STORE_ID));
не может быть успешным, потому что нет реально загружаемого магазина для администратора
Часто я использую такой шаблон:
// 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());
В противном случае иногда после выполнения скрипта обновления ваши посетители будут перенаправлены на страницу администратора, а не на внешний интерфейс.
Обновить:
Я неверно истолковал вопрос ниже, поэтому вот новая попытка объяснить ^^
Сценарии обновления вызываются из более глубокого метода в ядре ( Mage_Core_Model_Resource_Setup::_modifyResourceDb(...)
)
Здесь я попытался перечислить стек
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)
и теперь взглянем на 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;
}
метод _initModules()
вызывается до $scopeCode
и $scopeType
определяется.
В настоящее время я не могу понять, где определяется предполагаемый запасной вариант.