Гаразд, для використання магазину адміністратора у ваших сценаріях оновлення просто використовуйте
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());
Інакше іноді після виконання сценарію оновлення відвідувачі будуть переадресовані на сторінку адміністратора, а не на фронтенд.
Оновлення:
Я неправильно тлумачив питання нижче, тож ось нова спроба пояснити ^^
Сценарії оновлення викликаються методом глибше в core ( 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
визначається.
В даний час я не можу зрозуміти, де визначено припущений запасний варіант.