-
The default order attribute has been added to the endpoint GET
/admin/customersendpoint+ <attribute name="order"> + <attribute name="createdAt">DESC</attribute> + </attribute>
- The
api/v2/shop/adjustments/{id}endpoint has been disabled.
ApiBundle is no longer experimental and is now following the same support policy as the rest of Sylius.
-
The following Command constructor signatures have changed:
Sylius\Bundle\ApiBundle\Command\Account\ChangeShopUserPassword:public function __construct( - public ?string $newPassword, + public string $newPassword, - public ?string $confirmNewPassword, + public string $confirmNewPassword, - public ?string $currentPassword, + public string $currentPassword, )
Sylius\Bundle\ApiBundle\Command\Catalog\AddProductReview:public function __construct( - public ?string $title, + public string $title, - public ?int $rating, + public int $rating, - public ?string $comment, + public string $comment, public string $productCode, public ?string $email = null, )
Sylius\Bundle\ApiBundle\Command\Account\ResetPasswordpublic function __construct( - public string $resetPasswordToken, + public string $token, public ?string $newPassword = null, public ?string $confirmNewPassword = null, )
Sylius\Bundle\ApiBundle\Command\Account\VerifyCustomerAccount:public function __construct( - public $token, + public string $token, + public ?string $channelCode = null, + public ?string $localeCode = null, )
-
The following Command Handlers constructor signatures have changed:
Sylius\Bundle\ApiBundle\CommandHandler\Account\SendAccountRegistrationEmailHandler:use Sylius\Bundle\CoreBundle\Mailer\AccountRegistrationEmailManagerInterface; use Sylius\Component\Mailer\Sender\SenderInterface; public function __construct( private UserRepositoryInterface $shopUserRepository, private ChannelRepositoryInterface $channelRepository, - private SenderInterface $emailSender, + private AccountRegistrationEmailManagerInterface $accountRegistrationEmailManager, )Sylius\Bundle\ApiBundle\CommandHandler\Account\SendAccountVerificationEmailHandler:use Sylius\Bundle\CoreBundle\Mailer\AccountVerificationEmailManagerInterface; use Sylius\Component\Mailer\Sender\SenderInterface; public function __construct( private UserRepositoryInterface $shopUserRepository, private ChannelRepositoryInterface $channelRepository, - private SenderInterface $emailSender, + private AccountVerificationEmailManagerInterface $accountVerificationEmailManager, )Sylius\Bundle\ApiBundle\CommandHandler\Account\SendResetPasswordEmailHandler:use Sylius\Bundle\CoreBundle\Mailer\ResetPasswordEmailManagerInterface; use Sylius\Component\Mailer\Sender\SenderInterface; public function __construct( - private SenderInterface $emailSender, private UserRepositoryInterface $shopUserRepository, private ChannelRepositoryInterface $channelRepository, + private ResetPasswordEmailManagerInterface $resetPasswordEmailManager, )Sylius\Bundle\ApiBundle\CommandHandler\Checkout\SendOrderConfirmationHandler:use Sylius\Bundle\CoreBundle\Mailer\OrderEmailManagerInterface; use Sylius\Component\Mailer\Sender\SenderInterface; public function __construct( - private SenderInterface $emailSender, private OrderRepositoryInterface $orderRepository, + private OrderEmailManagerInterface $orderEmailManager, )Sylius\Bundle\ApiBundle\CommandHandler\Checkout\SendShipmentConfirmationEmailHandler:use Sylius\Bundle\CoreBundle\Mailer\ShipmentEmailManagerInterface; use Sylius\Component\Mailer\Sender\SenderInterface; public function __construct( - private SenderInterface $emailSender, private ShipmentRepositoryInterface $shipmentRepository, + private ShipmentEmailManagerInterface $shipmentEmailManager, )Sylius\Bundle\ApiBundle\CommandHandler\SendContactRequestHandler:use Sylius\Bundle\CoreBundle\Mailer\ContactEmailManagerInterface; use Sylius\Component\Mailer\Sender\SenderInterface; public function __construct( - private SenderInterface $emailSender, private ChannelRepositoryInterface $channelRepository, + private ContactEmailManagerInterface $contactEmailManager, ) -
The constructor signature of
Sylius\Bundle\ApiBundle\Serializer\ChannelDenormalizerhas been changed:use Sylius\Component\Resource\Factory\FactoryInterface; public function __construct( private FactoryInterface $channelPriceHistoryConfigFactory, + private FactoryInterface $shopBillingDataFactory ) -
The constructor signature of
Sylius\Bundle\ApiBundle\EventSubscriber\TaxonDeletionEventSubscriberhas been changed:use Sylius\Component\Core\Promotion\Checker\TaxonInPromotionRuleCheckerInterface; public function __construct( private ChannelRepositoryInterface $channelRepository, + private TaxonInPromotionRuleCheckerInterface $taxonInPromotionRuleChecker, ) -
The
Sylius\Bundle\ApiBundle\ApiPlatform\Bridge\Symfony\Bundle\Action\SwaggerUiActioncontroller has been removed. Therefore, theapi_platform.swagger.action.uiservice ID points to the API Platform'sSwaggerUiActioncontroller. -
The following services have been removed:
Sylius\Bundle\ApiBundle\Swagger\AdminAuthenticationTokenDocumentationNormalizerSylius\Bundle\ApiBundle\Swagger\ShopAuthenticationTokenDocumentationNormalizerSylius\Bundle\ApiBundle\Swagger\ProductDocumentationNormalizerSylius\Bundle\ApiBundle\Swagger\ProductImageDocumentationNormalizerSylius\Bundle\ApiBundle\Swagger\ProductSlugDocumentationNormalizerSylius\Bundle\ApiBundle\Swagger\ProductVariantDocumentationNormalizerSylius\Bundle\ApiBundle\Swagger\ShippingMethodDocumentationNormalizerSylius\Bundle\ApiBundle\Swagger\PathHiderDocumentationNormalizerSylius\Bundle\ApiBundle\Swagger\AcceptLanguageHeaderDocumentationNormalizer
Responsibility of these services has been moved to the corresponding services tagged with
sylius.open_api.modifier:Sylius\Bundle\ApiBundle\OpenApi\Documentation\AdminAuthenticationTokenDocumentationModifierSylius\Bundle\ApiBundle\OpenApi\Documentation\ShopAuthenticationTokenDocumentationModifierSylius\Bundle\ApiBundle\OpenApi\Documentation\ProductDocumentationModifierSylius\Bundle\ApiBundle\OpenApi\Documentation\ProductImageDocumentationModifierSylius\Bundle\ApiBundle\OpenApi\Documentation\ProductSlugDocumentationModifierSylius\Bundle\ApiBundle\OpenApi\Documentation\ProductVariantDocumentationModifierSylius\Bundle\ApiBundle\OpenApi\Documentation\ShippingMethodDocumentationModifierSylius\Bundle\ApiBundle\OpenApi\Documentation\PathHiderDocumentationModifierSylius\Bundle\ApiBundle\OpenApi\Documentation\AcceptLanguageHeaderDocumentationModifier
-
All usages of
ApiPlatform\Core\Api\IriConverterInterfacehave been switched to its non-deprecated counterpartApiPlatform\Api\IriConverterInterface. Due to that, the constructor and usage in the following classes have been changed accordingly:Sylius\Bundle\ApiBundle\Controller\GetProductBySlugActionSylius\Bundle\ApiBundle\Controller\UploadAvatarImageActionSylius\Bundle\ApiBundle\EventListener\AdminAuthenticationSuccessListenerSylius\Bundle\ApiBundle\EventListener\AuthenticationSuccessListenerSylius\Bundle\ApiBundle\Filter\Doctrine\CatalogPromotionChannelFilterSylius\Bundle\ApiBundle\Filter\Doctrine\ProductVariantCatalogPromotionFilterSylius\Bundle\ApiBundle\Filter\Doctrine\ProductVariantOptionValueFilterSylius\Bundle\ApiBundle\Filter\Doctrine\ProductVariantOptionValueFilterSylius\Bundle\ApiBundle\Filter\Doctrine\TaxonFilterSylius\Bundle\ApiBundle\Serializer\ChannelPriceHistoryConfigDenormalizerSylius\Bundle\ApiBundle\Serializer\ProductNormalizerSylius\Bundle\ApiBundle\Serializer\ProductVariantNormalizerSylius\Bundle\ApiBundle\Serializer\ZoneDenormalizer
-
The
Sylius\Bundle\ApiBundle\Filter\Doctrine\CatalogPromotionChannelFilterservice and class has been renamed toSylius\Bundle\ApiBundle\Filter\Doctrine\ChannelsAwareChannelFilter.
-
The following endpoints short names have been changed:
AdminResetPasswordRequest->AdministratorAccountResetPasswordRequest->CustomerShopUserToken->CustomerandSecurityAdminUserToken->AdministratorandSecurityContactRequest->ContactVerifyCustomerAccount->Customer
-
The item operation path for ProductVariantTranslation resource has been changed:
GET/admin/product-variant-translation/{id}->GET/admin/product-variant-translations/{id}
-
The following shop endpoints for getting the translation resources have been removed:
GET/shop/taxon-translations/{id}GET/shop/product-translations/{id}GET/shop/product-variant-translations/{id}GET/shop/shipping-method-translations/{id}
The fields those endpoint were exposing are available on their respective translation subject resources.
-
The following endpoints regarding authentication tokens have been changed:
POST/admin/authentication-tokens->POST/admin/administrators/tokenPOST/shop/authentication-tokens->POST/shop/customers/token
-
The following endpoints regarding password reset have been changed:
POST/admin/reset-password-requests->POST/admin/administrators/reset-passwordPATCH/admin/reset-password-requests/{resetPasswordToken}->PATCH/admin/administrators/reset-password/{token}POST/shop/reset-password-requests->POST/shop/customers/reset-passwordPATCH/shop/reset-password-requests/{resetPasswordToken}->PATCH/shop/customers/reset-password/{token}
-
The following endpoints regarding customer account verification have been changed:
POST/shop/account-verification-requests->POST/shop/customers/verifyPATCH/shop/account-verification-requests/{token}->PATCH/shop/customers/verify/{token}
-
The following endpoints regarding contact requests have been changed:
POST/shop/contact-requests->POST/shop/contact
-
Update in Translations Handling
The process for creating or updating translations via the API has been refined. Now, the locale for each translation is determined directly from its key, making the explicit transmission of the
localefield redundant. Although the API continues to support the explicit sending of thelocalefield but in cases of a mismatch between the key and an explicitly sent locale, the API will respond with theSylius\Bundle\ApiBundle\Exception\TranslationLocaleMismatchException. -
Product and taxon editing at
/admin/product-taxons/{id}operation has been disabled to improve data integrity. To modify a product-taxon relationship remove the existing one and create a new one. -
The keys for adjustment endpoints' responses have been changed:
{ ... - "order_item": "string", + "orderItem": "string", - "order_item_unit": "string", + "orderItemUnit": "string", ... } -
The
customerkey has been removed from admin address endpoints' responses. -
The
statuskey has been removed from shop product review endpoints' responses. -
The
authorkey has been changed in shop product review endpoints' responses:{ ... - "author": "string(IRI)", + "author": { + "@id": "string(IRI)", + "@type": "string", + "firstName": "string", + }, } -
Resolving the
pathproperty of every resource implementingSylius\Component\Core\Model\ImageInterfacehas been changed to always rely on filters. The default filter has been set tosylius_original, but can be changed via configuration:sylius_api: default_image_filter: custom_filter
Due to this change the previously used configuration node
product_image_prefixand its corresponding parametersylius_api.product_image_prefixhave been removed.
-
All the
:readserialization groups are now split toindexandshow. The:readserialization groups are now considered deprecated and will no longer be used in the future. There is a BC layer that will allow you to use the:readserialization groupSylius\Bundle\ApiBundle\SerializerContextBuilder\ReadOperationContextBuilderby adding thereadserialization group to your context. To configure skipping adding the index and show or read serialization groups to the context, add the following configuration to yourconfig/packages/_sylius.yamlfile:sylius_api: serialization_groups: skip_adding_index_and_show_groups: true skip_adding_read_group: true
-
All Sylius serialization groups have been prefixed with
sylius:. If you extend any Sylius resources, you should update your serialization groups to use the new prefix. Non-prefix serialization groups are considered deprecated and will be removed in Sylius 2.0. -
Typo in the constraint validator's alias returned by
Sylius\Bundle\ApiBundle\Validator\Constraints\ChangedItemQuantityInCart::validatedByhas been fixed. Previously it wassylius_api_validator_changed_item_guantity_in_cartand now it issylius_api_validator_changed_item_quantity_in_cart. -
The
sylius.api.product_taxon_filterfilter has been removed and its functionality has been superseded by thesylius.api.search_filter.taxon.codefilter. The usage stays the same. -
Due to changes with images'
pathproperty resolving the following services have been changed to make their context broader:Sylius\Bundle\ApiBundle\Serializer\ProductImageNormalizer->Sylius\Bundle\ApiBundle\Serializer\ImageNormalizerSylius\Bundle\ApiBundle\OpenApi\Documentation\ProductImageDocumentationModifier->Sylius\Bundle\ApiBundle\OpenApi\Documentation\ImageDocumentationModifierSylius\Bundle\ApiBundle\Provider\ProductImageFilterProviderInterface->Sylius\Bundle\ApiBundle\Provider\ImageFiltersProviderInterfaceSylius\Bundle\ApiBundle\Provider\LiipProductImageFilterProvider->Sylius\Bundle\ApiBundle\Provider\LiipImageFiltersProvider