从 Magento 中的货件跟踪事件获取跟踪 ID

Get tracking ID from shipment track event in Magento

我正在尝试从 Magento 1.9.0.1 中的 sales_order_shipment_track_save_after 事件中获取跟踪号。由于某种原因,该活动似乎不包括发货,因为 $observer->getEvent()->getShipment() returns NULL。我使用了错误的事件吗?

这些是我的代码的相关部分:

config.xml(模块)

<events>
  <sales_order_shipment_track_save_after>
    <observers>
      <pixelstore_sms>
        <type>model</type>
        <class>pixelstore_sms/observer</class>
        <method>shipments</method>
      </pixelstore_sms>
    </observers>
  </sales_order_shipment_track_save_after>
</events>

Observer.php(型号)

public function shipments($observer) {
    $event = $observer->getEvent();
    $shipment = $event->getShipment();
    if (!$shipment) {
        Mage::log('shipments event did not contain shipment', null, 'track.log');
        return false;
    }
    // We never reach this far
    $trackings = $shipment->getAllTracks();
    $tracking = end($trackings);
    $trackingId = $tracking->getNumber();
    // Here I would prefer to have the tracking ID in $trackingId
}

您可能已经猜到了,if 语句匹配。 get_class() 表明观察者是 Varien_Event_Observer.

我是不是观察到了错误的事件,还是我应该调用其他方法来获取跟踪 ID?

即使作为基础观察者,它也应该能够检索订单对象。

public function shipments(Varien_Event_Observer $observer) {
$event = $observer->getEvent();
$shipment = $event->getShipment();
if (!$shipment) {
Mage::log('shipments event did not contain shipment', null, 'track.log');
return false;
}
// We never reach this far
$trackingId = $observer->getOrder()->getTrackingNumbers();
// Here I would prefer to have the tracking ID in $trackingId
}

我发现该事件包含键 track 下的 Mage_Sales_Model_Order_Shipment_Track 对象。这意味着我可以通过 $event->getData('track')$event['track'] 或只是 $event->getTrack() 从事件中获取它。所以这就是最终解决我的问题的方法:

public function shipments(Varien_Event_Observer $observer) {
  $event = $observer->getEvent();
  $track = $event->getTrack();
  $trackingId = $track->getNumber();

  // The shipment itself can be found in the track object,
  // and the order inside the shipment object:
  $shipment = $track->getShipment();
  $order = $shipment->getOrder();
}

这都是对实际事件中包含的内容的误解。