As far as I can tell, when a script is run outside of Magento, observers are not invoked when an event is fired. Why? How do I fix it?
Below is the original issue th
My first guess would be the event you're trying to hook into is a
or
event, because it looks like only
events fire when you run a command line script.
Magento has this concept called "areas". Areas are sort-of like individual applications that live in the system (but not quite, I'm still a little fuzzy on the concept).When you setup a config.xml with your observers, you're either placing them in a
tag, a
tag, or a
tag.
When it comes to events, Magento only loads up areas that it has to deal with for a particualr request. So, the
area always gets loaded. However, the
or
areas only get loaded up if the application gets to the controller dispatch. Specifcally, in the following file/line
File: app/code/core/Mage/Core/Controller/Varien/Action.php
Mage::app()->loadArea($this->getLayout()->getArea());
That never happens with a command line application. Only the
area gets loaded.
So, as mentioned in the first paragraph, my guess is your observer isn't firing because Magento never loads the
area of the application. As for solutions, you could try moving your observer to the
area. You could also try manually calling
Mage::app()->loadArea(Mage_Core_Model_App_Area::AREA_FRONTEND);
although, you'd be loading ALL observers in the
area, many of which have probably been created assuming a web browser context.
If none of that helps, take a look at the dispatchEvent
method on the Mage_Core_Model_App
class. That's where event observers get called.