-
Starting with Sylius 1.13, the
SyliusPriceHistoryPlugin
is included. If you are currently using the plugin in your project, we recommend following the upgrade guide located here. -
The
Sylius\Bundle\CoreBundle\CatalogPromotion\Command\RemoveInactiveCatalogPromotion
command and its handlerSylius\Bundle\CoreBundle\CatalogPromotion\CommandHandler\RemoveInactiveCatalogPromotionHandler
have been deprecated. UseSylius\Bundle\CoreBundle\CatalogPromotion\Command\RemoveCatalogPromotion
command instead. -
Passing
Symfony\Component\Messenger\MessageBusInterface
toSylius\Bundle\CoreBundle\CatalogPromotion\Processor\CatalogPromotionRemovalProcessor
as a second and third argument is deprecated. -
Not passing
Sylius\Bundle\CoreBundle\CatalogPromotion\Announcer\CatalogPromotionRemovalAnnouncerInterface
toSylius\Bundle\CoreBundle\CatalogPromotion\Processor\CatalogPromotionRemovalProcessor
as a second argument is deprecated. -
Not passing
Doctrine\Persistence\ObjectManager
toSylius\Component\Core\Updater\UnpaidOrdersStateUpdater
as a fifth argument is deprecated. -
To allow to autoconfigure order processors and cart context and define a priority for them in
1.13
we have introducedSylius\Bundle\OrderBundle\Attribute\AsCartContext
andSylius\Bundle\OrderBundle\Attribute\AsOrderProcessor
attributes. By default, Sylius still configures them using interfaces, but this way you cannot define a priority. If you want to define a priority, you need to set the following configuration in your_sylius.yaml
file:sylius_core: autoconfigure_with_attributes: true
and use one of the new attributes accordingly to a type of your class, e.g.:
<?php declare(strict_types=1); namespace App\OrderProcessor; use Sylius\Bundle\OrderBundle\Attribute\AsOrderProcessor; use Sylius\Component\Order\Model\OrderInterface; use Sylius\Component\Order\Processor\OrderProcessorInterface; #[AsOrderProcessor(priority: 10)] //priority is optional //#[AsOrderProcessor] can be used as well final class OrderProcessorWithAttributeStub implements OrderProcessorInterface { public function process(OrderInterface $order): void { } }
-
Not passing
Sylius\Component\Core\Checker\ProductVariantLowestPriceDisplayCheckerInterface
toSylius\Component\Core\Calculator\ProductVariantPriceCalculator
as a first argument is deprecated. -
Not passing an instance of
Symfony\Component\PropertyAccess\PropertyAccessorInterface
toSylius\Bundle\CoreBundle\Validator\Constraints\HasEnabledEntityValidator
as the second argument is deprecated. -
Class
\Sylius\Bundle\ShopBundle\Calculator\OrderItemsSubtotalCalculator
has been deprecated. Order items subtotal calculation is now available on the Order model\Sylius\Component\Core\Model\Order::getItemsSubtotal
. -
The way of getting variants prices based on options has been changed, as such the following services were deprecated, please use their new counterpart.
- instead of
Sylius\Component\Core\Provider\ProductVariantsPricesProviderInterface
useSylius\Component\Core\Provider\ProductVariantMap\ProductVariantsMapProviderInterface
- instead of
Sylius\Component\Core\Provider\ProductVariantsPricesProvider
useSylius\Component\Core\Provider\ProductVariantMap\ProductVariantsPricesMapProvider
- instead of
Sylius\Bundle\CoreBundle\Templating\Helper\ProductVariantsPricesHelper
useSylius\Component\Core\Provider\ProductVariantMap\ProductVariantsPricesMapProvider
- instead of
Sylius\Bundle\CoreBundle\Twig\ProductVariantsPricesExtension
useSylius\Bundle\CoreBundle\Twig\ProductVariantsMapExtension
Subsequently, the
sylius_product_variant_prices
twig function is deprecated, usesylius_product_variants_map
instead.To add more data per variant create a service implementing the
Sylius\Component\Core\Provider\ProductVariantMap\ProductVariantMapProviderInterface
and tag it withsylius.product_variant_data_map_provider
. - instead of
-
Using Guzzle 6 has been deprecated in favor of Symfony HTTP Client. If you want to still use Guzzle 6 or Guzzle 7, you need to install
composer require php-http/guzzle6-adapter
orcomposer require php-http/guzzle7-adapter
depending on your Guzzle version. Subsequently, you need to register the adapter as aPsr\Http\Client\ClientInterface
service as the following:services: Psr\Http\Client\ClientInterface: class: Http\Adapter\Guzzle7\Client # for Guzzle 6 use Http\Adapter\Guzzle6\Client instead
-
The constructor of
Sylius\Bundle\AdminBundle\Controller\NotificationController
has been changed:public function __construct( - private ClientInterface $client, - private MessageFactory $messageFactory, + private ClientInterface|DeprecatedClientInterface $client, + private RequestFactoryInterface|MessageFactory $requestFactory, private string $hubUri, private string $environment, + private ?StreamFactoryInterface $streamFactory = null, ) { ... }
-
The
sylius.http_message_factory
service has been deprecated. UsePsr\Http\Message\RequestFactoryInterface
instead. -
The
sylius.http_client
has become an alias topsr18.http_client
service. -
The
sylius.payum.http_client
has become a service ID of newly createdSylius\Bundle\PayumBundle\HttpClient\HttpClient
. -
Validation translation key
sylius.review.rating.range
has been replaced bysylius.review.rating.not_in_range
in all places used by Sylius. Thesylius.review.rating.range
has been left for backward compatibility and will be removed in Sylius 2.0. -
The
payum/payum
package has been replaced by concrete packages likepayum/core
,payum/offline
orpayum/paypal-express-checkout-nvp
. If you need any other component so far provided bypayum/payum
package, you need to install it explicitly. -
PostgreSQL migration support has been introduced. If you are using PostgreSQL, we assume that you have already created a database schema in some way. All you need to do is run migrations, which will mark all migrations created before Sylius 1.13 as executed.