mavimedia / shopware6-primary-order-delivery
Automatically sets primaryOrderDeliveryId for orders created via API without the cart flow
Package info
github.com/mavimedia/shopware6-primary-order-delivery
Type:shopware-platform-plugin
pkg:composer/mavimedia/shopware6-primary-order-delivery
Requires
- shopware/core: ~6.7.0
README
A Shopware 6.7 plugin that automatically sets the primaryOrderDeliveryId field for orders created via the API.
Problem
Shopware 6.7 introduced a new primary_order_delivery_id column on the order table. The admin order list uses this field to display the shipping address via order.primaryOrderDelivery.shippingOrderAddress.
However, this field is only set through the cart/checkout flow (OrderConverter). Orders created directly via the Admin API — for example by ChannelEngine, ERP systems, or migration tools — do not go through this flow, leaving the field NULL. As a result, the shipping address column in the admin order list is empty for these orders.
This is a known Shopware core issue (see shopware/shopware#14051) that has not been resolved as of Shopware 6.7.9.0.
Solution
This plugin registers an event subscriber on order_delivery.written. Whenever a delivery is created for an order that has no primaryOrderDeliveryId set, the plugin automatically assigns the first delivery as the primary one.
Requirements
- Shopware 6.7.x
- PHP 8.2+
Installation
Via Composer (recommended)
composer require mavimedia/primary-order-delivery php bin/console plugin:refresh php bin/console plugin:install --activate MavimediaPrimaryOrderDelivery php bin/console cache:clear
Manual
Copy the MavimediaPrimaryOrderDelivery directory to custom/plugins/ or packages/, then:
php bin/console plugin:refresh php bin/console plugin:install --activate MavimediaPrimaryOrderDelivery php bin/console cache:clear
Fixing existing orders
This plugin only handles new orders going forward. To fix existing orders with a missing primaryOrderDeliveryId, run the following SQL on your database:
UPDATE `order` o INNER JOIN `order_delivery` od ON od.order_id = o.id AND od.order_version_id = o.version_id SET o.primary_order_delivery_id = od.id, o.primary_order_delivery_version_id = od.version_id WHERE o.primary_order_delivery_id IS NULL;
Then clear the cache:
php bin/console cache:clear
License
MIT