Sie können keine Ereignisse verwenden, die sich auf das Lagerartikelmodell beziehen, da Magento mithilfe einer optimierten SQL-Abfrage den Lagerbestand für alle bestellten Artikel gleichzeitig unter Umgehung des Modells verringert.
Ich löste dieses Problem mit einer Umschreibung, in der Mage_CatalogInventory_Model_Stock
ich ein zusätzliches Ereignis hinzufügte:
<?php
/**
* Add events to observe stock qty change
*
* @author Fabian Schmengler
*
*/
class SGH_ShippingExpress_Model_CatalogInventory_Stock
extends Mage_CatalogInventory_Model_Stock
{
const EVENT_CORRECT_STOCK_ITEMS_QTY_BEFORE = 'cataloginventory_stock_item_correct_qty_before';
const EVENT_CORRECT_STOCK_ITEMS_QTY_AFTER = 'cataloginventory_stock_item_correct_qty_after';
/**
* (non-PHPdoc)
* @see Mage_CatalogInventory_Model_Stock::registerProductsSale()
*/
public function registerProductsSale($items)
{
Mage::dispatchEvent(self::EVENT_CORRECT_STOCK_ITEMS_QTY_BEFORE, array(
'stock' => $this,
'items_obj' => (object)array('items' => &$items),
'operator' => '-'
));
$result = parent::registerProductsSale($items);
Mage::dispatchEvent(self::EVENT_CORRECT_STOCK_ITEMS_QTY_AFTER, array(
'stock' => $this,
'items' => $items,
'fullsave_items' => $result,
'operator' => '-'
));
return $result;
}
/**
* (non-PHPdoc)
* @see Mage_CatalogInventory_Model_Stock::revertProductsSale()
*/
public function revertProductsSale($items)
{
Mage::dispatchEvent(self::EVENT_CORRECT_STOCK_ITEMS_QTY_BEFORE, array(
'stock' => $this,
'items_obj' => (object)array('items' => &$items),
'operator' => '+'
));
$result = parent::revertProductsSale($items);
Mage::dispatchEvent(self::EVENT_CORRECT_STOCK_ITEMS_QTY_AFTER, array(
'stock' => $this,
'items' => $items,
'fullsave_items' => $result,
'operator' => '+'
));
return $result;
}
}
Dann kann der Beobachter für cataloginventory_stock_item_correct_qty_after
so aussehen:
/**
* @var $items array array($productId => array('qty'=>$qty, 'item'=>$stockItem))
*/
$items = $observer->getItems();
foreach ($items as $productId => $item) {
$stockItem = $item['item'];
$product = $stockItem->getProduct();
// Do anything you need with $stockItem and $product here
}
Ich empfehle, keine umfangreichen Verarbeitungsvorgänge oder zusätzlichen Datenbankaufrufe (die erforderlich sind, um beispielsweise festzustellen, ob das Produkt nicht vorrätig ist) durchzuführen, sondern die Produkte einer Warteschlange hinzuzufügen, die von einem Cronjob verarbeitet wird, um die zusätzliche Ladezeit für das zu minimieren Benutzer.